[leetcode 16.01 ]交换数字的几种方式(纯炫技)

编写一个函数,不用临时变量,直接交换numbers = [a, b]ab的值。

示例:

输入: 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;
}

posted @   强里秋千墙外道  阅读(12)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
点击右上角即可分享
微信分享提示