交换两个数的方法总结

方法一:使用宏

#define Exchage(a, b) \
do{           \
        a += b;\
        b = a - b; \  
        a = a - b  \
}while(0)


方法二:使用第三个变量

void inplace_swap(int *a, int *b)
{
    int tmp;
    tmp =*a;
    *a = *b;
    *b = tmp;
}

方法三:利用布尔环的属性,加法逆元。

void inplace_swap(int *x, int *y)
{
    *y ^= *x;
    *x ^= *y;
    *y ^= *x;
}

方法四:利用整数运算的属性。

void inplace_swap(int *a, int *b)
{
    *a = *a + *b;
    *b = *a - *b;
    *a = *a - *b;
}

第四种方法关于存在溢出的问题,补码加上形成一个阿尔贝群,以及表达式(x+y)-x求值得到y,无论加法是否溢出,而 (x+y)-y总是会求值得到x。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值