C语言中,位运算完成 加、减、乘、除

//位运算实现加法(整数部分)
/*
设:  x = 5(101)  y = 6(110)
则:先通过 异或( ^ )完成“逢二不进一” 在通过按位与( & )主要判断两边是1的情况 在进行左移( << )完成进位,如下。
 1: 101    2: 101    3:  0011  4:         0011
   ^ 110  & <<1 110      ^  1000      & <<1  1000
     011       1000         1011             0000
结果为:1011
*/
int add(int a,int b)
{
	while (b)
	{
		int temp = a^b;
		b = (a&b)<< 1;
		a = temp;
	}
	return a;
}

//减法部分
/*
减法就跟简单了,我们只用把b变成负数,当作加法来用.如下:
设: x = 5(101)  y = 6(110)
    5 + (-6) = -1  和 5 - 6 = -1 
	5 + 6 = 11  和  5 - (-6) = 11 是等价的;
*/
int sub(int a,int b)
{
	b = ~b + 1;       //求补码;
	return add(a, b);
}

//乘法部分
/*
   乘法和加法一样了..例如
   2 * 3 = 3 + 3

*/
int mult(int a,int b)
{
	int temp = 0;
	while (a)
	{
		temp = add(temp, b);
		a = sub(a, 1);
	}
	return temp;
}

//除法部分
/*
   除法和乘法一样不做多解释了
*/
int divson(int a, int b)
{
	int cnt = 0;
	while (b <= a)
	{
		a = sub(a, b);
		cnt++;
	}
	return cnt;

}

int main()
{
	int x = 10, y = 2;
	printf("%d + %d = %d\n",x,y,add(x, y));
	printf("%d - %d = %d\n",x,y,sub(x, y));
	printf("%d * %d = %d\n",x,y,mult(x, y));
	printf("%d / %d = %d\n",x,y,divson(x, y));

	system("pause");
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值