|
論壇說明 |
歡迎您來到『史萊姆論壇』 ^___^ 您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的! 請點擊這裡:『註冊成為我們的一份子!』 |
|
主題工具 | 顯示模式 |
2007-10-19, 08:40 PM | #1 |
長老會員
|
疑問 - C++ 程式錯誤.........
#include <iostream>
#include <cstdlib> using namespace std; void swap(int,int,int); int main(void) { int a=3,b=5,c=2; cout << "Before swap..."; cout << "a=" << a << ",b=" << b << ",c=" << c <<endl; cout << "After swap..."; swap(a,b,c); cout << "a=" << a << ",b=" << b <<",c=" << c << endl; system("pause"); return 0; } void swap(int x,int y,int z) { int temp; if (z>y) { temp=z; y=z; z=temp; } if (y>x) { temp=x; x=y; y=temp; } if (z>y) { temp=y; y=z; z=temp; } return; } 不知道該怎麼修改耶........ 此帖於 2007-10-19 11:48 PM 被 leowang 編輯. |
__________________ 金錢的數量,決定馬子的漂亮 硬碟的容量,決定男人的力量 製作Mail Logo按這裡 |
|
送花文章: 257,
|
2007-10-19, 10:03 PM | #2 (permalink) |
榮譽會員
|
語法:
#include <iostream> #include <cstdlib> using namespace std; void swap(int,int,int); int main(void) { int a=3,b=5,c=2; cout << "Before swap..."; cout << "a=" << a << ",b=" << b << ",c=" << c <<endl; cout << "After swap..."; swap(a,b,c); cout << "a=" << a << ",b=" << b <<",c=" << c << endl; system("pause"); return 0; } void swap(int x,int y,int z) { int temp; if (x>y){ x=x; y=y; }else { temp=x; x=y; y=temp; } if (x>z){ x=x; z=z; }else { temp=x; x=z; z=temp; } if (y>z){ y=y; z=z;}else { temp=y; y=z; z=temp; } return; } |
__________________ |
|
送花文章: 1110,
|
2007-10-19, 10:42 PM | #3 (permalink) | |
註冊會員
|
這是個傳值換位問題,我直接從你函式那解說
以下紅色部分是你要修改的地方,藍色部分是解說 引用:
語法:
#include<iostream> #define swap(a,b) a^=b^=a^=b; using namespace std; int main(){ int a,b; cin >>a>>b; swap(a,b); cout <<a<<" "<<b; system("pause"); return 0; } 語法:
#define swap(a,b) a^=b^=a^=b; 這個是運用到"漢明碼"的規則寫的偷懶函式 (我看到時也嚇到!!好強阿~竟然能降寫) 漢明碼( ^ )是把數字化為0.1表示(2進位)做運算 一樣的為1(正確),不同的為0(錯誤) 例: 7=111 , 5=101 -> 7^5=101 14=1110 , 9=1001 -> 14^9=1000 而define 是C語言裡的定義,就像是執行函式 例: define a=100 , 則程式裡所有的a皆=100 接下來是重點,為何兩個變數數值交換可以這樣表示? 因為a^=b^=a^=b要由後往前看先看a^=b^= "a^=b" a^=b -> a^b=a 現在我們代數字進去(a=7 , b=5) a^b=111^101=101=a -> a=101 b^a=101^101=111=b -> b=111 a^b=101^111=101=a -> a=101 則a.b不就數值交換嗎?看的懂嗎?懂話這用法記起來!! 另外" ^ "還有其他用法,在C語言裡若不計算是的話可表指數 例: a=2^6=64 只有變數對等時可以使用(建議不要這樣做) 若在計算是中要用指數表示的話建議用"pow(2,6)" pow(a,b)=a連成b次,這是C語言裡的內定函式 歡迎各位高手切磋指教一翻^^ 另外小弟我11月初要代表學校比賽,祝福我吧!! 此帖於 2007-10-22 12:46 PM 被 joebin 編輯. 原因: *改成& = =太久沒用忘記嚕XD.....抱歉...... |
|
送花文章: 15,
|
向 joebin 送花的會員:
|
Admin1 (2007-10-19)
感謝您發表一篇好文章 |
2007-10-20, 02:56 AM | #6 (permalink) |
註冊會員
|
撲~哈哈.....注意一看發現我有漏打一個";",抱歉我家沒有灌C++編譯程式
所以直接寫出來沒校正過><(註:我還未成年,別叫我大大,我沒那麼老= =) 關於你要問的問題,我上一偏發文是針對你問的"不能交換數值而言" 若要用函式來寫泡泡~看看以下是否是你要的解答(用你的程式為底改寫) 語法:
#include<iostream> using namespace std; void swap(int &x,int &y,int &z){ int temp; if (z>y){ temp=z; y=z; z=temp; } if (y>x){ temp=x; x=y; y=temp; } if (z>y){ temp=y; y=z; z=temp; } } int main(){ int a=3,b=5,c=2; cout << "Before swap..."; cout << "a=" << a << ",b=" << b << ",c=" << c <<endl; cout << "After swap..."; swap(a,b,c); //*表值.&表位置 cout << "a=" << a << ",b=" << b <<",c=" << c << endl; system("pause"); return 0; } 依賴編譯程式校正成慣~"~壞習慣,不好~弟弟有練過~哥哥不能學喔!! 此帖於 2007-10-22 12:46 PM 被 joebin 編輯. 原因: 感謝mini提醒 |
送花文章: 15,
|
2007-10-20, 09:04 AM | #7 (permalink) |
管理版主
|
不論是氣泡排列 還是xx排列
講到排列 最好是用 陣列去做 數值的交換不用到暫存變數的話 可以用 如果 a 大於 b 然後 a = a xor b b = a xor b a = a xor b 這就是上面 joebin 提到的 用c++的簡寫特性 就可寫成 a^=b^=a^=b; ====================== 氣泡排列是個人認為最簡單易懂 且容易掌控花費時間的一種排列方式 語法:
#include <cstdlib> #include <iostream> using namespace std; void swap(int &i, int &j){ /* i=i^j; j=i^j; i=i^j; */ i^=j^=i^=j; } int main(int argc, char *argv[]) { int aTmp[]={3,5,2}; int i,j; cout << "Before swap..."; cout << "a=" << aTmp[0] << ",b=" << aTmp[1] << ",c=" << aTmp[2] << endl; cout << "After swap..."; for (i=0; i<(3-1); i++){ for (j=(i+1); j<3; j++){ if (aTmp[i] > aTmp[j]) swap(aTmp[i], aTmp[j]); } } cout << "a=" << aTmp[0] << ",b=" << aTmp[1] <<",c=" << aTmp[2] << endl; system("pause"); return 0; } 此帖於 2007-10-20 03:39 PM 被 mini 編輯. |
送花文章: 2017,
|
向 mini 送花的會員:
|
joebin (2007-10-20)
感謝您發表一篇好文章 |
|
|
相似的主題 | ||||
主題 | 主題作者 | 討論區 | 回覆 | 最後發表 |
Linux操作系統下乙太網卡的安裝及配置 | psac | 網路疑難應用技術研討區 | 1 | 2004-06-06 05:45 AM |
電腦當機後出現藍底白字劃面,倒數100秒後重新開機是那裡出現問題呢? | fishers | 硬體疑難使用問題討論區 | 18 | 2003-04-01 12:57 PM |