acm-位操作

位操作:

&  与     两个位都为1时,结果才为1

 

|  或    两个位都为0时,结果才为0

 

^   异或   两个位相同为0,相异为1

 

~  取反   0变1,1变0

 

<<  左移   各二进位全部左移若干位,高位丢弃,低位补0

 

>>  右移   各二进位全部右移若干位,对无符号数,高位补0,有符号数,各编译器处理方法不一样,有的补符号位(算术右移),有的补0(逻辑右移)

 

注意: 

1.位操作只能用于整形数据,对float和double类型进行位操作会被编译器报错。

2.位操作符的运算优先级比较低,因为尽量使用括号来确保运算顺序

 

操作技巧:

1.判断奇偶

判断最后一位是0还是1 

2.交换

利用异或

3.变幻符号

取反后加1

4.如果要获得第i位的数据,判断((data&(0X<<i))==0),若真,为0,假,为1; 

5.如果要设置第i位为1,data=(data|(0X1<<i)); 

6.如果要设置第i位为0,data=(data&(~(0X1<<i))); 

7.如果要将第i位取反,data=(data^(0X1<<i); 

8.如果要取出一个数的最后一个1(lowbit):(data&(-data)) 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值