剑指offer不使用新变量,交换两个变量的值,C++实现

Posted wanglei5205

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指offer不使用新变量,交换两个变量的值,C++实现相关的知识,希望对你有一定的参考价值。

# 题目

      不使用新变量,交换两个变量的值。

# 思路

方法一:使用加减法操作,交换两个变量的值。

      A = A+B

      B = A-B

      A = A-B

方法二:使用异或运算,交换两个变量的值

      A = A^B

      B = A^B

      A = A^B

# 代码

#include <iostream>
using namespace std;

void fun1(int m,int n)
{
    cout << "方法一,基于加减法,交换两个变量" << endl;
    m = m + n;
    n = m - n;
    m = m - n;
    cout<<m<<"    "<<n<<endl;
}

void fun2(int m,int n)
{
    cout << "方法二,基于异或运算,交换两个变量" << endl;
    m = m^n;
    n = m^n;
    m = m^n;
    cout<<m<<"    "<<n<<endl;
}
int main()
{
    int m = 10;
    int n = 20;
    cout << "原始数值" << endl;
    cout<<m<<"    "<<n<<endl;
    fun1(m,n);
    fun2(m,n);
    return 0;
}

以上是关于剑指offer不使用新变量,交换两个变量的值,C++实现的主要内容,如果未能解决你的问题,请参考以下文章

C语言中如何交换两个指针变量的的值

剑指offer算法_位运算求和

javajava 如何不使用第三个变量来交换两个数的值

交换两个变量的值,不使用第三个变量的四种法方

不利用临时变量,交换两个变量的值

(转)交换两个变量的值,不使用第三个变量的四种法方