三種方法交換兩個數的值
阿新 • • 發佈:2019-01-31
第一種,也是最原始的方法,使用中間變數,將a與b的值進行交換#include<stdio.h>int main()
{
int a = 10;
int b = 20;
int c = 0;
printf("交換之前:%d %d", a, b);
c = a;
a = b;
b = c;
printf("\n交換之後:%d %d", a, b);
system("pause");
return 0;
}第二種方法,利用加減運演算法則,即b=a+b-a,a=a+b-b的原理,但這種方法有一缺陷就是當a+b的值足夠大時,超出了資料型別的大小,這時就會出現錯誤,在編寫程式碼時應該注意#include<stdio.h>int main()
{
int a = 10;
int b = 20;
printf("交換之前:%d %d", a, b);
a = a + b; //將a+b賦給a,此時a的值變為a+b
b = a - b; //此時a是a+b,a+b-b就是a的值,所以此句語句是將a賦給b
a = a - b; //此時a是a+b,b是a,a-b就是a+b-a,也就是b,所以此句語句是將b賦給a
printf("\n交換之後:%d %d", a, b);
system("pause");
return 0;
}第三種方法是最理想的一種方法,沒有越界的缺點,利用二進位制按位異或的運演算法則#include<stdio.h>int main()
{
int a = 10;
int b = 20;
printf("交換之前:%d %d", a, b);
a = a^b;
b = a^b;
a = a^b;
printf("\n交換之後:%d %d",a, b);
system("pause");
return 0;
}
{
int a = 10;
int b = 20;
int c = 0;
printf("交換之前:%d %d", a, b);
c = a;
a = b;
b = c;
printf("\n交換之後:%d %d", a, b);
system("pause");
return 0;
}第二種方法,利用加減運演算法則,即b=a+b-a,a=a+b-b的原理,但這種方法有一缺陷就是當a+b的值足夠大時,超出了資料型別的大小,這時就會出現錯誤,在編寫程式碼時應該注意#include<stdio.h>int main()
{
int a = 10;
int b = 20;
printf("交換之前:%d %d", a, b);
a = a + b; //將a+b賦給a,此時a的值變為a+b
b = a - b; //此時a是a+b,a+b-b就是a的值,所以此句語句是將a賦給b
a = a - b; //此時a是a+b,b是a,a-b就是a+b-a,也就是b,所以此句語句是將b賦給a
printf("\n交換之後:%d %d", a, b);
system("pause");
return 0;
}第三種方法是最理想的一種方法,沒有越界的缺點,利用二進位制按位異或的運演算法則#include<stdio.h>int main()
{
int a = 10;
int b = 20;
printf("交換之前:%d %d", a, b);
a = a^b;
b = a^b;
a = a^b;
printf("\n交換之後:%d %d",a, b);
system("pause");
return 0;
}