下面列出几种方法:
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 }