先貼上我的源**:
#include
void fun(int m,int n);
static int m=-1;
int main(int argc,char **argv)
; fun(data,10);
return 0;
}void fun(int data,int n)
{ int i=0;
int j;
int tmp;
int k;
printf("要排序的資料:");
for(;i
i;j--)
{ if(data[j]
執行結果:
氣泡排序的原理:
比較相鄰兩個元素的大小,如果第乙個比第二個大則交換兩個的位置。
對每一對相鄰元素作同樣的工作,從開始第一對到結尾的最後一對。
針對所有的元素重複以上的步驟,除了最後乙個。
持續每次對越來越少的元素重複上面的步驟,直到沒有任何一對數字需要比較。
我的**中跟描述的不一樣我是通過陣列的最後兩個元素開始比較將最小的資料首先放到陣列頭部。
這段**中有幾個地方需要注意:
第乙個設定了乙個靜態變數m。這個變數是為了標記一趟排序是否發生了交換,如果一趟下來沒有發生資料交換則說明已經是最終的有序陣列了。從而避免沒必要的持續遍歷。如果一陣列中的資料是有序的比如1 2 3 4 5則一次遍歷局可以完成陣列的排序,當然也可以看出如果是逆序排列則比如45 4 3 2 1則需要的時間複雜度是最高的。
第二個注釋的資料交換。我們可以申請乙個整型用於存放中間變數,但是在交換兩個數的時候是可以不用第三個整型變數的,該交換兩個數的方式**於演算法:a=a+b;b=a-b;a=a-b;
排序演算法 氣泡排序
一.氣泡排序的過程 公升值排序 1.將第乙個記錄的關鍵字與第二個記錄的關鍵字進行比較,若key 1 key 2 則交換。然後比較第二個與第三個,依此類推,直到第n 1個與第n個比較為止,第一趟排序完後,記錄最大的關鍵字會被排在最後面。2.將記錄的前n 1個關鍵字進行第二趟比較交換,直到前n 1個中最...
排序演算法 氣泡排序
從基礎重新抓起。氣泡排序 每次從陣列頭到尾選出最大或者最小的,排到尾部或者頭部。以排序結果從小到大為例 每次從陣列中把最大的調換到末尾。eg.元素個數 count,需要找count 1次 外迴圈,最後一次不用再做比較了 每次從頭到末尾沒有確定的資料中找最大的 內迴圈 做法就是比較相鄰兩個元素的大小,...
排序演算法 氣泡排序
排序演算法是處理資料最基礎的演算法,掌握各種排序演算法有利以後遇到資料時的處理。首次學習,先學習氣泡排序。氣泡排序原理 對一組待排序資料x1,x2,x3,x4,x5,x6,x7.xn,氣泡排序演算法指標 這裡的指標並不是實際的指標,只是為方便而假象的乙個類似指標的東西 從第乙個資料開始,與其後面的乙...