不使用运算符实现“四则运算

加法:用^来计算加法;主要要考虑进位,而只有两个数的相同位都为1时才会出现进位,所以用&来计算是否要进位。
int getSum(int a, int b){
    int c = a&b, xor = a^b;
    return c==0? xor : getSum(xor, c);
}
减法:计算机中会把减法转换为“+反码”,因此与加法相似。
乘法:可转换为“左移”与“加法”的组合,来实现任意的乘法。
除法:对于除数是2的阶乘的除法可转换为“右移”,但对除数为其它时的情况暂时没有更高效的解决方法,所以一般除法要比乘法慢。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值