亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++面試題之數(shù)a、b的值互換(不使用中間變量)

 更新時間:2016年07月04日 11:33:31   作者:rl529014  
這篇文章主要介紹了不使用中間變量,C++實現(xiàn)數(shù)a、b的值互相轉(zhuǎn)換操作,感興趣的小伙伴們可以參考一下

題目要求:將數(shù)a、b的值進行交換,并且不使用任何中間變量。

程序如下:

 #include<stdio.h>

void swapValue1(int &a, int &b) //使用中間變量交換數(shù)據(jù)
{
 int temp = a;
 a = b;
 b = temp;
}

void swapValue2(int &a, int &b)//使用加減運算完成數(shù)據(jù)交換
{
 a = a + b;
 b = a - b;
 a = a - b; 
}

void swapValue3(int &a, int &b) //使用位運算交換數(shù)據(jù)
{
 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;
} 

運行結(jié)果:

解析:
第一種:使用中間變量來達到交換數(shù)據(jù)的目的,這是最大眾的方法,當然了不滿足本題的要求。 

第二種:
使用簡單的加減操作來達到交換a、b值得目的。
缺點:a+b和a-b時,可能會到導致數(shù)據(jù)溢出。 

第三種:
采用位運算的方法,按位異或運算。(建議采用這種方式)
異或運算:相同的二進制位異或運算為0,不相同的二進制位異或運算為1。 

關(guān)于位運算的知識,參考http://chabaoo.cn/article/87880.htm

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論