位运算中的一些技巧

交换连个数

方法一:利用位运算交换两个数

a = a ^ b;
b = a ^ b; //右边等价于a^b^b=a
a = a ^ b; //此时b=a; 此式右边等于a^b^a=b

方法二:

需要考虑a+b会不会超过a表达的数值范围,导致内存溢出

a=a+b;
b=a-b;// 右边等价于a+b-b=a
a=a-b;//此时b等于a,右边等价于a+b-a=b

int 的最大值

Integer.MAX_VALUE
十进制:2147483647
二进制:1111111 11111111 11111111 11111111

求2的幂

2 的幂次方,有一个特点是,最高位为1,地位全为0,因而2 的次幂满足 (n &(n-1)) ==0

求4的幂 (0x55555555)

0x55555555
二进制:01010101 01010101 01010101 01010101
特点:二进制中,奇数项全为1,偶数项全为0;
用法:可以求4的次幂,4的次幂的特点是,自由最高位的奇数项为1,因此只要是4的次幂,则满足 (n & 0x55555555) == n

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值