【位操作笔记】交换数值 使用加减法

交换数值 使用加减法

交换数值指的是,两个数的数值交换,例如x = 1,y = 2,交换之后变成x = 2,y = 1。

算法说明

通过加法和减法来实现交换数值。

实现代码

方法一:

#define SWAP(a, b) ((&(a) == &(b)) || \
                    (((a) -= (b)), ((b) += (a)), ((a) = (b) - (a))))

方法二:

#define SWAP2(a, b) ((&(a) == &(b)) || \
                    (((a) += (b)), ((b) = (a) - (b)), ((a) -= (b))))

方法三:

#define SWAP3(a, b) ((&(a) == &(b)) || \
                    (((a) = (b) - (a)), ((b) -= (a)), ((a) = (a) + (b))))

这三个方法的代码,一开始会通过&(a) == &(b)检测a和b是否在内存中的同一位置,如果可以保证不会处于同一内存位置,可以删除&(a) == &(b)

算法计算过程

方式一:

计算分3个步骤:

1.	a = a - b;
2.	b = b + a;
3.	a = b - a;

将1直接带入2中,可以得到b = b + a - b = a;

将1,2带入3中,可以得到a = a - (a - b) = b;

完成a,b两个数值交换。

例如:

a = 1,b = 2
a = a - b = 1 - 2 = -1
b = b + a = 2 - 1 = 1
a = b - a = 1 - (-1) = 2

完成两个数的交换。

方式二:

计算分3个步骤:

1.	a = a + b;
2.	b = a - b;
3.	a = a - b;

将1直接带入2中,可以得到b = a + b - b = a;

将1,2带入3中,可以得到a = a + b - a = b;

完成a,b两个数值交换。

例如:

a = 1,b = 2
a = a + b = 1 + 2 = 3
b = a - b = 3 - 2 = 1
a = a - b = 3 - 1 = 2

完成两个数的交换。

方式三:

计算分3个步骤:

1.	a = b - a;
2.	b = b - a;
3.	a = a + b;

将1直接带入2中,可以得到b = b - (b - a) = a;

将1,2带入3中,可以得到a = b - a + a = b;

完成a,b两个数值交换。

例如:

a = 1,b = 2
a = b - a = 2 - 1 = 1
b = b - a = 2 - 1 = 1
a = a + b = 1 + 1 = 2

完成两个数的交换。


[参考资料]

Bit Twiddling Hacks By Sean Eron Anderson

[Hacker’s Delight] 作者: Henry S. Warren Jr.


本文链接:https://blog.csdn.net/u012028275/article/details/112110922

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值