C++面試題之數a、b的值交換(不應用中央變量)。本站提示廣大學習愛好者:(C++面試題之數a、b的值交換(不應用中央變量))文章只能為提供參考,不一定能成為您想要的結果。以下是C++面試題之數a、b的值交換(不應用中央變量)正文
標題請求:將數a、b的值停止交流,而且不應用任何中央變量。
法式以下:
#include<stdio.h>
void swapValue1(int &a, int &b) //應用中央變量交流數據
{
int temp = a;
a = b;
b = temp;
}
void swapValue2(int &a, int &b)//應用加減運算完成數據交流
{
a = a + b;
b = a - b;
a = a - b;
}
void swapValue3(int &a, int &b) //應用位運算交流數據
{
a^=b;
b^=a;
a^=b;
}
int main()
{
int a1 = 1, b1 = 2;
int a2 = 3, b2 = 4;
int a3 = 5, b3 = 6;
swapValue1(a1, b1);
swapValue2(a2, b2);
swapValue3(a3, b3);
printf("a= %d b= %d\n",a1, b1);
printf("a= %d b= %d\n",a2, b2);
printf("a= %d b= %d\n",a3, b3);
return 0;
}
運轉成果:
解析:
第一種:應用中央變量來到達交流數據的目標,這是最年夜眾的辦法,固然了不知足本題的請求。
第二種:
應用簡略的加減操作來到達交流a、b值得目標。
缺陷:a+b和a-b時,能夠會到招致數據溢出。
第三種:
采取位運算的辦法,按位異或運算。(建議采取這類方法)
異或運算:雷同的二進制位異或運算為0,不雷同的二進制位異或運算為1。
關於位運算的常識,參考http://www.jb51.net/article/87880.htm
以上就是本文的全體內容,願望對年夜家的進修有所贊助,也願望年夜家多多支撐。