java實現幾個2的n次方和的分解

來源:互聯網
上載者:User

java實現幾個2的n次方和的分解,如15 分解為2的3次+2的2次+2的1次+2的0次如47分解為:2的5次+2的3次+2的2次+2的1次+2的0次這是一道許可權分配中遇到的問題,如許可權為47,如上分解,我想要0,1,2,3,5 如9 我想要0,3 就是2的n次方和,求一個程式實現給定任意一個2的n(n不重複)次方和將其分解,取出其次數放入一個數組中,謝謝,急用!如 17 只有[0,4]分別是2的0次方和2的4次方和。

問題補充:

麻煩lzhuan665你把思路說詳細點好不好,就只說轉化為二進位,下一步怎麼做呢,能不能實現下給我看看啊,我是個初學者,麻煩你幫幫忙啊?
2010-12-6 22:52

最佳答案
import java.util.Scanner;
public class Binary {
 public static void main(String[] args) {
 System.out.println("請輸入想轉換的數字:");
Scanner in =new Scanner(System.in);
int num=in.nextInt();
 String numStr=Integer.toBinaryString(num);
System.out.println(numStr);
StringBuffer bf=new StringBuffer();
 for(int i=0;i<numStr.length();i++){
 if(numStr.charAt(i)!='0'){ bf.append(numStr.length()-1-i);
 }
}
int arr[]=new int[bf.length()];
 for(int i=0;i<bf.length();i++)
{
 arr[i]=bf.charAt(i)-'0';
 System.out.print(arr[i]);
 }
System.out.println(bf.toString()); }}

給你個思路,轉換為2進位就可以了public class TestBin { public static void main(String[] args) { String s=Integer.toBinaryString(47); System.out.println (s); } }

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.