当前位置:首页 > 编程笔记 > 正文
已解决

如何不引入第三个中间变量进行两数交换

来自网友在路上 183883提问 提问时间:2023-10-12 21:22:40阅读次数: 83

最佳答案 问答题库838位专家为你答疑解惑

但在大厂面试中,有一道非常经典的数字交换题目:如何在不引入第三个中间变量的情况下,完成两个数字的交换。
这里可以用到一个数学上的技巧:

a = a + b;
b = a - b;
a = a - b;

除了这种先加后减的写法,还有一种先减后加的写法:

a = b - a;
b = b - a;
a = a + b;

但这两种方式都可能导致数字越界。
更好的方案是通过位运算完成数字交换:

a = a ^ b;
b = b ^ a;
a = a ^ b;

查看全文

99%的人还看了

猜你感兴趣

版权申明

本文"如何不引入第三个中间变量进行两数交换":http://eshow365.cn/6-19256-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!