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

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

这里可以用到一个数学上的技巧:

java 复制代码
a = a + b;
b = a - b;
a = a - b;

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

java 复制代码
a = b - a;
b = b - a;
a = a + b;

但这两种方式都可能导致数字越界。

更好的方案是通过位运算完成数字交换:

java 复制代码
a = a ^ b;
b = b ^ a;
a = a ^ b;
相关推荐
hu_yuchen4 分钟前
C++:Lambda表达式
开发语言·c++·算法
烨然若神人~10 分钟前
算法训练营第五天 | 454.四数相加II\ 383. 赎金信\15. 三数之和\ 18. 四数之和
算法
一只鱼^_13 分钟前
牛客周赛 Round 91
数据结构·c++·算法·数学建模·面试·贪心算法·动态规划
啊阿狸不会拉杆30 分钟前
人工智能数学基础(三):微积分初步
人工智能·python·算法·数学建模
2401_858286111 小时前
CC52.【C++ Cont】滑动窗口
开发语言·数据结构·c++·算法·leetcode·滑动窗口
mvufi2 小时前
day31 第八章 贪心算法 part05
算法·贪心算法
珊瑚里的鱼2 小时前
第一讲 | 算法复杂度
c语言·开发语言·数据结构·笔记·算法·visualstudio·visual studio
啊阿狸不会拉杆3 小时前
人工智能数学基础(四):线性代数
人工智能·python·数学·算法·机器学习
玖剹3 小时前
矩阵区域和 --- 前缀和
数据结构·c++·算法·leetcode·矩阵·动态规划·1024程序员节
zwz宝宝3 小时前
第三次作业(密码学)
java·数据结构·算法