[leetcode 16.01 ]交换数字的几种方式(纯炫技)
编写一个函数,不用临时变量,直接交换numbers = [a, b]
中a
与b
的值。
示例:
输入: numbers = [1,2] 输出: [2,1]
class Solution {
public:
vector<int> swapNumbers(vector<int>& numbers) {
numbers[0] = numbers[0] ^ numbers[1];
numbers[1] = numbers[0] ^ numbers[1];
numbers[0] = numbers[0] ^ numbers[1];
return numbers;
}
};
使用异或的方法,不会出现溢出的情况。但是注意如果传入的变量为同一个内存的变量,则会被抹为0
以交换a、b为例
大一使用的,简单的使用辅助变量来交换
void swap(int &a,int &b){
int tmp = a;
a=b;
b=tmp;
}
大四使用的,巧妙使用加减法来交换两个值
void swap(int &a,int &b){
a = a + b;
b = a - b;
a = a - b;
}
研究生期间学会的,巧妙使用异或运算,不会出现溢出的情况,也就是上面的方法
void swap(int &a,int &b){
a = a ^ b;
b = a ^ b;
a = a ^ b;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)