计蒜客 交换高低位

题目:

对于一个数的二进制表示,交换其高低位顺序。比如,对于整数 123523532,
123523532 的二进制表示:

00000111 01011100 11010001 11001100
交换后的结果为
11001100 11010001 01011100 00000111

在计蒜课上看到这题,感觉很有趣,因为之前看过二进制枚举的知识。这是一题代码填空的题目。


import java.util.Scanner;


class Main {
public static void print(long x) {//这一部分是将输入的数字转换成二进制
for (int i = 31; i >= 0; --i) {
       if ((x&(1L<<i)) > 0) System.out.print("1");
       else System.out.print("0");
       if (i % 8 == 0) {
           if (i > 0) System.out.print(" ");//用空格将每8个数分开
           else System.out.print("\n");
       }
   }
}


public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
long x = scanner.nextLong();
        long mask = (1L<<32)-1;// -1的存储就是0xffffffff, 你可以认为,0-1就是10000...000(1后面32个0) - 1=1111...111(32个1)。 这个33位上作借位的1其实是想象的。

print(x);
        // 在下方填入一行代码
        x = ((x<<24)&mask)+((x>>24)&mask)+((x<<8)&0x00ff0000)+((x>>8)&0x0000ff00);//利用二进制和十六进制
print(x);
}
}

看很久,因为代码里面还有一些不同的知识,后来大致看明白了这个代码,但是还是不会进行交换。于是在网上看了大神的题解。终于知道怎么转换了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值