不用加减乘除做加法
第一步:不考虑进位对每一位相加,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;
}