二进制总结

1.编码

正数负数
原码0本体1本体
补码0本体按位取反+1(符号位始终为1)
反码0本体按位取反(符号位始终为1)

2.分类

有符号:
无符号:

3. 位运算

3.1 与 、或、异或
与(&)0&0=01&0=01&1=1
或(|)0|0=00|1=11|1=1
异或(^)0^0=01^0=11^1=0
3.2 左移
m<<n

表示把m左移n位。往左移n位的时候,最左边的n位将被丢弃,同时在最右边补上n个0.

exp:

00001010<<2=00101000

100**01010<<3=01010**000

3.3 右移
m>>n

表示把m右移n位。往右移的时候,最右边的n位将被丢弃。

如果数字之前是一个正数,则右移之后在最左边补n个0;

如果数字之前是一个负数,则右移之后在最左边补n个1.

exp:

00001010>>2=00000010

10001010>>3=11110001

3.4 应用
3.4.1 移位运算代替乘除法
3.4.2 右移一位 == 除以2
3.4.3 左移一位 == 乘以2
二进制中1的个数

int NumberOf1(int n)
{
    int count = 0;
    while(n)
    {
        ++count;
        n = (n-1) & n;
    }
    return count;
}

不用加减法做加法
int Add(int num1,int num2)
{
    int sum,carry;
    do
    {
        sum = num1 ^ num2;
        carry = (num1 & num2) << 1;
        num1 = sum;
        num2 = carry;
    }
    while(num2 !=0 );
    
    return num1;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值