下面列出几种方法:
1)算术运算
1 int a,b; 2 a=10;b=12; 3 a=b-a; //a=2;b=12 4 b=b-a; //a=2;b=10 5 a=b+a; //a=12;b=10
它的原理是把A,B看作是数轴上的点,围绕两点间的距离来进行运算。
缺点:因为是int类型,有可能造成数据溢出。
2)指针地址操作
1 if(a<b){ 2 a=(int*)(b-a); 3 b=(int*)(b-(int(a)&0x0000ffff)); 4 a=(int*)(b+(int(a)&0x0000ffff)); 5 } 6 else{ 7 b=(int*)(a-b); 8 a=(int*)(a-(int(b)&0x0000ffff)); 9 b=(int*)(a+(int(b)&0x0000ffff)); 10 }
3)位运算
1 int a=10,b=12; //a=1010^b=1100; 2 a=a^b; //a=0110^b=1100; 3 b=a^b; //a=0110^b=1010; 4 a=a^b; //a=1100=12;b=1010;
4)利用栈的先入后出实现
1 int exchange(int x,int y) { 2 stack S; 3 push(S,x); 4 push(S,y); 5 x=pop(S); 6 y=pop(S); 7 }