还是两个数的交换问题
#include<iostream.h>
void main()
{
????int *a,*b;
????int x,y;
????int c;
????cout<<"Input a b:";
????cin>>x>>y;
????a=new int(x);
????b=new int(y);
????c=b-a; //記錄a與b的首地址距離
????a=a+(c^0x80000000); /*
???????????????????????????????????????a地址加上距離c得到b地址
????????????????????????????????????? (因為*a與*b之間的大小關(guān)系,
?????????????????????????????????????? c^0x80000000目的是為了
?????????????????????????????????????? 對距離值取反,否則就會出
?????????????????????????????????????? 現(xiàn)地址增減方向上的錯誤)
???????????????????????????????????????*/
????b=b-(c^0x80000000);
????cout<<"After Swap"<<endl;
????cout<<"a Value:"<<*a<<endl;
????cout<<"b Value:"<<*b<<endl;
}
也是用了中間變量,可能這樣不夠完善,但和c=a;a=b;b=c;比較起來要好得多。
畢竟c=a;a=b;b=c;當數(shù)據(jù)量大了的時候是有程序崩潰的危險的。
現(xiàn)在這個中間變量只記錄兩首地址的距離,在存儲量上應(yīng)該沒問題。
這些應(yīng)該是最基礎(chǔ)的東西,復習下也好~~~
轉(zhuǎn)載于:https://www.cnblogs.com/Random/archive/2007/03/20/681865.html
總結(jié)
以上是生活随笔為你收集整理的还是两个数的交换问题的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 关于《如何阅读一本书》
- 下一篇: RIA风格的GIS软件还有多远?