史萊姆論壇

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

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

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

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

Google 提供的廣告


 
 
主題工具 顯示模式
舊 2006-11-02, 12:26 AM   #1
onlyaway
榮譽勳章

勳章總數
UID -
在線等級:
文章: n/a
精華:
預設 程式 - 汽泡排序的問題

輸入: 20 個隨機產生,小於99999且無順序的正整數。
測試輸入資料依序為:89, 8889, 80089, 43, 50043
24, 12345, 54321, 79, 79586
3467, 21589, 400, 5689, 63
380, 961, 7824, 5, 26

處理: 將「測試輸入資料」,由小排到大。
排序中並累計資料交換之次數。

輸出: 每排一回合,列印未完成之中間結果一次,並列印該回合資料交換之次數,共十九回合。排序完成後,加印資料交換之總次數。

要求:
1. 必須使用副程式。

2. 測試輸入資料筆數改變時,不影響程式之正確執行。

以下是我寫的程式..可是還是有錯誤 各位大大麻煩幫我看一下
流程圖不知道要怎麼寫 會的大大麻煩交一下


語法:
 
#include <iostream.h>
#define number 5 //要排序的資料個數 void bubble (int a[],int n) //副程式名稱bubble { //氣泡排序法 int i,j,t,temp,sum=0; for(i=0;i<n;i++) { for(j=0;j<n-1;j++) { if(a[j]>a[j+1]) { temp=a[j+1]; a[j+1]=a[j]; a[j]=temp; } } sum++; cout<<endl<<"交換之次數:"<<sum<<endl; for(t=0;t<n;t++) { cout<<a[t]<<" "; } } } void main() { int i,list[number],j; cout<<"*********氣泡排序法*********"<<endl; for(j=0;j<number;j++) cin>>list[j]; cout<<"排序前:"; for(i=0;i<number;i++) { cout<<list[i]<<" "; } bubble(list,number); cout<<endl<<"排序後:"; for(i=0;i<number;i++) { cout<<list[i]<<" "; } }

 
送花文章: 0, 收花文章: 0 篇, 收花: 0 次
回覆時引用此帖
 



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

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


所有時間均為台北時間。現在的時間是 01:15 AM


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


SEO by vBSEO 3.6.1