不用加减乘除做加法与不用新的变量交换两个变量的值

本文介绍如何使用位运算实现两个整数的加法而不需要传统的加减乘除运算,并展示了两种不使用额外变量交换两个整数的方法。

不用加减乘除做加法

第一步:不考虑进位对每一位相加,0加0的0,0加1的1,1加0的1,1加1的0,这个结果和异或的结果相同

第二步:只有1加1会进位,这个结果和与的结果相同

第三步:将两步的结果相加,重复上面的操作,直到不产生进位

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;
}

不用新的变量交换两个变量的值

方法一

void swap(int num1,int num2)

{

num1=num1+num2;

num2=num1-num2;

num1=num1-num2;

}

方法二

两个相同的数和另一个数异或操作结果为不相同的那个数,相当于0和任何数异或为原来的数本身,0^0 的0,0^1的1

1^1^1为,1,  1^1^0为0, 0^0^1为1, 0^0^0为0,如110与101与110结果为101

void swap(int num1,int num2)

{

num1=num1^num2;

num2=num1^num2;

num1=num1^num2;

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值