[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;
}


版权声明:本文为weixin_39445116原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。