这是要存进数组的二进制数,长度为2的4个一组,长度为3的8个一组,以此类推
我的想法是这个数等于2的n次方减1的时候,把它重新赋值为0
这不就是从0到2的n次方减1的数转成二进制吗
参考如下(n的值是从键盘输入的)
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt(); //得到n的值
int v = (int) (Math.pow(2, n)-1);
char[] c = new char[20];
int t,nmb;
for(int i = 0;i<=v;i++){
t = i;
nmb = 0;
while(t!= 0){
c[nmb++] = (char) ('0' + t%2);
t/=2;
}
for(int j=0;j<n-nmb;j++)
System.out.print('0');
for(int j=nmb-1;j>=0;j--)
System.out.print(c[j]);
System.out.println();
}
}
简单来说,就是区间[0, 2的n次方-1]转二进制,并且二进制字符串的位数=n,你想的可能过于复杂了,就按照你的写法如下:
public static void main(String[] args) {
// 暴力解法,指数容易爆炸,这里就模拟4次吧
for (int i = 1; i < 5; i++) {
StringBuilder sb = new StringBuilder();
for (int j = 0; j < Math.pow(2, i); j++) {
sb.append(toBinary(j, i)).append(",");
}
System.out.println(sb.substring(0, sb.length() - 1));
}
// out:
// 0,1
// 00,01,10,11
// 000,001,010,011,100,101,110,111
// 0000,0001,0010,0011,0100,0101,0110,0111,1000,1001,1010,1011,1100,1101,1110,1111
}
// 添加前导0的方法
public static String toBinary(int val, int digit) {
return Integer.toBinaryString((1 << digit) | val).substring(1);
}
看不懂题目的意思
估计你得写好几个for循环嵌套 每个for循环 输出每位的0/1