史萊姆論壇

返回   史萊姆論壇 > 專業主討論區 > 程式語言討論區
忘記密碼?
論壇說明

歡迎您來到『史萊姆論壇』 ^___^

您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的!

請點擊這裡:『註冊成為我們的一份子!』

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2007-10-19, 08:40 PM   #1
leowang 帥哥
長老會員
 
leowang 的頭像
榮譽勳章
UID - 2461
在線等級: 級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時
註冊日期: 2002-12-06
文章: 4729
精華: 0
現金: 101679 金幣
資產: 668410953 金幣
預設 疑問 - 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 編輯.
__________________
https://lh3.googleusercontent.com/RuWvUdY-gxGU8oiOD6DIEoKZhLD-Hn-ITKj1LgD3QY6MehzkoddZNew3f3AFLA8dbxbnK-uiFipPzO3GpT5iL4VTIKCiYhgfnQiP5DROmn_5YIpA9zrseGljottMSbiTsw=w1280

金錢的數量,決定馬子的漂亮
硬碟的容量,決定男人的力量

製作Mail Logo按這裡
leowang 目前離線  
送花文章: 257, 收花文章: 1161 篇, 收花: 4928 次
回覆時引用此帖
舊 2007-10-19, 10:03 PM   #2 (permalink)
榮譽會員
 
猜謎人 的頭像
榮譽勳章
UID - 14438
在線等級: 級別:99 | 在線時長:10294小時 | 升級還需:106小時級別:99 | 在線時長:10294小時 | 升級還需:106小時級別:99 | 在線時長:10294小時 | 升級還需:106小時級別:99 | 在線時長:10294小時 | 升級還需:106小時級別:99 | 在線時長:10294小時 | 升級還需:106小時級別:99 | 在線時長:10294小時 | 升級還需:106小時級別:99 | 在線時長:10294小時 | 升級還需:106小時級別:99 | 在線時長:10294小時 | 升級還需:106小時級別:99 | 在線時長:10294小時 | 升級還需:106小時
註冊日期: 2002-12-19
住址: 虎爛宮解籤詩處
文章: 18702
現金: 10109 金幣
資產: 2886912 金幣
預設

語法:
#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;
}
我這樣寫結果竟然沒有作氣泡排列
__________________
http://i171.photobucket.com/albums/u287/sad_jellyfish/net-pic/s_zpsf91b1q3t.jpghttp://i171.photobucket.com/albums/u287/sad_jellyfish/gif/banner.gifhttp://i171.photobucket.com/albums/u287/sad_jellyfish/gif/kkk_zps3punatke.gif
猜謎人 目前離線  
送花文章: 1110, 收花文章: 16299 篇, 收花: 83322 次
回覆時引用此帖
舊 2007-10-19, 10:42 PM   #3 (permalink)
註冊會員
 
joebin 的頭像
榮譽勳章

勳章總數
UID - 270712
在線等級: 級別:2 | 在線時長:16小時 | 升級還需:5小時級別:2 | 在線時長:16小時 | 升級還需:5小時
註冊日期: 2007-06-06
住址: 過去*現在*未來
文章: 42
精華: 0
現金: 58 金幣
資產: 118 金幣
預設

這是個傳值換位問題,我直接從你函式那解說

以下紅色部分是你要修改的地方,藍色部分是解說

引用:
作者: leowang 查看文章
void swap(int &x,int &y,int &z)
{
//&x.&y.&z的意思是你&x存放3,&y存放5,&z存放2
//若不用&(位址)來儲存的話,那值雖然有帶入運算,但結果不會帶出

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;
}
//void函式不需return,只有int函式才要
}
另外小弟給各位一個快速互換值的方法

語法:
#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.....抱歉......
joebin 目前離線  
送花文章: 15, 收花文章: 18 篇, 收花: 28 次
回覆時引用此帖
向 joebin 送花的會員:
Admin1 (2007-10-19)
感謝您發表一篇好文章
舊 2007-10-19, 10:50 PM   #4 (permalink)
管理員
 
Admin1 的頭像
榮譽勳章
UID - 112827
在線等級: 級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時級別:29 | 在線時長:972小時 | 升級還需:48小時
註冊日期: 2007-02-18
VIP期限: 0000-00
文章: 3507
精華: 0
現金: 1702 金幣
資產: 10196 金幣
預設

引用:
作者: joebin 查看文章

歡迎各位高手切磋指教一翻^^

另外小弟我11月初要代表學校比賽,祝福我吧!!

要.加.油.喔


Admin1 目前離線  
送花文章: 8870, 收花文章: 2195 篇, 收花: 5820 次
回覆時引用此帖
舊 2007-10-19, 11:41 PM   #5 (permalink)
長老會員
 
leowang 的頭像
榮譽勳章
UID - 2461
在線等級: 級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時級別:111 | 在線時長:12773小時 | 升級還需:219小時
註冊日期: 2002-12-06
文章: 4729
精華: 0
現金: 101679 金幣
資產: 668410953 金幣
預設

其實我是要寫比大小
想寫成氣泡排序 但用副程式方式來寫 也想用指標 但不會

寫完之後竟然沒有比較大小耶 奇怪

joebin大大 所修改的程式碼不能動耶
leowang 目前離線  
送花文章: 257, 收花文章: 1161 篇, 收花: 4928 次
回覆時引用此帖
舊 2007-10-20, 02:56 AM   #6 (permalink)
註冊會員
 
joebin 的頭像
榮譽勳章

勳章總數
UID - 270712
在線等級: 級別:2 | 在線時長:16小時 | 升級還需:5小時級別:2 | 在線時長:16小時 | 升級還需:5小時
註冊日期: 2007-06-06
住址: 過去*現在*未來
文章: 42
精華: 0
現金: 58 金幣
資產: 118 金幣
預設

引用:
作者: leowang 查看文章
其實我是要寫比大小
想寫成氣泡排序 但用副程式方式來寫 也想用指標 但不會

寫完之後竟然沒有比較大小耶 奇怪

joebin大大 所修改的程式碼不能動耶
撲~哈哈.....注意一看發現我有漏打一個";",抱歉我家沒有灌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提醒
joebin 目前離線  
送花文章: 15, 收花文章: 18 篇, 收花: 28 次
回覆時引用此帖
舊 2007-10-20, 09:04 AM   #7 (permalink)
管理版主
 
mini 的頭像
榮譽勳章
UID - 4144
在線等級: 級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時
註冊日期: 2002-12-07
文章: 13249
精華: 0
現金: 26241 金幣
資產: 3024051 金幣
預設

不論是氣泡排列 還是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 編輯.
mini 目前離線  
送花文章: 1999, 收花文章: 7957 篇, 收花: 26749 次
回覆時引用此帖
向 mini 送花的會員:
joebin (2007-10-20)
感謝您發表一篇好文章
舊 2007-10-20, 12:12 PM   #8 (permalink)
註冊會員
 
joebin 的頭像
榮譽勳章

勳章總數
UID - 270712
在線等級: 級別:2 | 在線時長:16小時 | 升級還需:5小時級別:2 | 在線時長:16小時 | 升級還需:5小時
註冊日期: 2007-06-06
住址: 過去*現在*未來
文章: 42
精華: 0
現金: 58 金幣
資產: 118 金幣
預設

感謝mini的提醒,不然我誤導他了XD

不過好奇一問,mini您的程式碼能跑嘛??

感覺好像不行~所以我擅自改了一點XD

不知道你的對還是我的對(沒編譯程式><)

請路過的看官有空幫忙跑跑看,謝!!

此帖於 2007-10-20 02:43 PM 被 joebin 編輯.
joebin 目前離線  
送花文章: 15, 收花文章: 18 篇, 收花: 28 次
回覆時引用此帖
舊 2007-10-20, 04:27 PM   #9 (permalink)
管理版主
 
mini 的頭像
榮譽勳章
UID - 4144
在線等級: 級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時級別:96 | 在線時長:9665小時 | 升級還需:132小時
註冊日期: 2002-12-07
文章: 13249
精華: 0
現金: 26241 金幣
資產: 3024051 金幣
預設

引用:
作者: joebin 查看文章
感謝mini的提醒,不然我誤導他了XD

不過好奇一問,mini您的程式碼能跑嘛??

感覺好像不行~所以我擅自改了一點XD

不知道你的對還是我的對(沒編譯程式><)

請路過的看官有空幫忙跑跑看,謝!!
用 DEV c++跑過
方才修正了一行
原本
for (j=i; j<3; j++){
改成
for (j=(i+1); j<3; j++){
如此才不會多做一次白工
mini 目前離線  
送花文章: 1999, 收花文章: 7957 篇, 收花: 26749 次
回覆時引用此帖
發文 回覆



發表規則
不可以發文
不可以回覆主題
不可以上傳附加檔案
不可以編輯您的文章

論壇啟用 BB 語法
論壇啟用 表情符號
論壇啟用 [IMG] 語法
論壇禁用 HTML 語法
Trackbacks are 禁用
Pingbacks are 禁用
Refbacks are 禁用

相似的主題
主題 主題作者 討論區 回覆 最後發表
資訊 - 電腦當機全集 psac 系統 & 硬體安裝及故障判斷技術文件 13 2006-08-24 10:48 AM
硬碟分區大師Partition Magic十種新技巧 psac 系統 & 硬體安裝及故障判斷技術文件 2 2006-03-31 03:40 PM
Linux操作系統下乙太網卡的安裝及配置 psac 網路疑難應用技術研討區 1 2004-06-06 05:45 AM
Ms Win 2000 Service Pack 4修補程式安裝和佈署指南 psac 作業系統操作技術文件 0 2004-02-24 04:26 PM
電腦當機後出現藍底白字劃面,倒數100秒後重新開機是那裡出現問題呢? fishers 硬體疑難使用問題討論區 18 2003-04-01 12:57 PM


所有時間均為台北時間。現在的時間是 06:53 PM


Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2024, Jelsoft Enterprises Ltd.


SEO by vBSEO 3.6.1