平沢唯丶
2022-01-13 15:14
采纳率: 100%
浏览 87
已结题

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

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

img

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

img

img


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

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 邀请回答

4条回答 默认 最新

  • 最佳回答

    这不就是从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();
            }
        }
    
    评论
    解决 1 无用
    打赏 举报 编辑记录
查看更多回答(3条)

相关推荐 更多相似问题