Java把二进制数循环移位再存入相应数组,我的方法很复杂而且还错了,求更好的方法代码

这是要存进数组的二进制数,长度为2的4个一组,长度为3的8个一组,以此类推

img

我的想法是这个数等于2的n次方减1的时候,把它重新赋值为0

img

img


才存了前几个数而且还不完整。有无更好的存入方法代码求解

这不就是从0到2的n次方减1的数转成二进制吗

参考如下(n的值是从键盘输入的)

img

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