这是要存进数组的二进制数,长度为2的4个一组,长度为3的8个一组,以此类推
我的想法是这个数等于2的n次方减1的时候,把它重新赋值为0
才存了前几个数而且还不完整。有无更好的存入方法代码求解
这是要存进数组的二进制数,长度为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();
}
}