码迷,mamicode.com
首页 > 其他好文 > 详细

位运算实现加减乘除

时间:2018-08-18 17:49:34      阅读:147      评论:0      收藏:0      [点我收藏+]

标签:gnu   add   minus   class   运算   int   nbsp   span   实现   

int Add(int a, int b)
{
    int sum = 0;
    while(b!=0)
    {
        sum = a^b;
        b = ((a&b)<<1);
        a = sum;
    }
    return sum;
}
int NegNum(int b) { return Add(~b, 1); }
int Minus(int a, int b) { return Add(a, NegNum(b)); }
bool isNeg(int a) { return a<0; }
int Multi(int a, int b) { int x = isNeg(a) ? NegNum(a) : a; int y = isNeg(b) ? NegNum(b) : b; int res = 0; while(y!=0) { if((y&1)!=0) res = Add(res, x); x <<= 1; y >>= 1; } return isNeg(a)==isNeg(b) ? res : NegNum(res); }
int Div(int a, int b) { int x = isNeg(a) ? NegNum(a) : a; int y = isNeg(b) ? NegNum(b) : b; int res = 0; for(int i=31; i>=0; i=Minus(i,1)) { if((x>>i) >= y) { res |= (1<<i); x = Minus(x, y<<i); } } return isNeg(a)==isNeg(b) ? res : NegNum(res); }

 

位运算实现加减乘除

标签:gnu   add   minus   class   运算   int   nbsp   span   实现   

原文地址:https://www.cnblogs.com/randyniu/p/9497519.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!