排序演算法是處理資料最基礎的演算法,掌握各種排序演算法有利以後遇到資料時的處理。首次學習,先學習氣泡排序。
氣泡排序原理:對一組待排序資料x1,x2,x3,x4,x5,x6,x7.......xn,氣泡排序演算法指標(這裡的指標並不是實際的指標,只是為方便而假象的乙個類似指標的東西)從第乙個資料開始,與其後面的乙個資料比較(假設是要求是從小到大排序),如果排序指標所指的資料比其後面的乙個資料大,那麼就把排序指標所指的資料和它後面的資料位置交換,一次比較完成之後,將排序指標加1指向下乙個資料,如此重複上面的過程直到排序指標指向第n個資料,從第乙個資料比較到最後乙個資料 ,資料中最大的乙個就被排到資料的最後(最大資料沉到最底下),然後又將排序指標指向第乙個資料,重複上面的比較過程,知道知道排序指標指向第n-1個資料,每比較一趟,下一次排序時指標所指的最後一位資料都要向前移動一位,知道排序指標所指的最後乙個資料是整個資料組的第乙個資料的時候,那麼說明排序finished!
演算法分析:
最好的時間複雜度:o(n),一趟掃瞄就完成排序,資料移動的次數為0:
最壞時間複雜度:n(n-1)/2=o(n^2),資料完全反序,每次比較都需要進行資料移動
平均時間複雜度:o(n^2),雖然氣泡排序不一定要比較n-1趟,但由於他每次移動的次數較多,故平均時間效能比較差.
演算法穩定性:氣泡排序時就地排序,是穩定的排序演算法。
**:
void bubblesort(void * data,int length)}}
}
排序演算法 氣泡排序
一.氣泡排序的過程 公升值排序 1.將第乙個記錄的關鍵字與第二個記錄的關鍵字進行比較,若key 1 key 2 則交換。然後比較第二個與第三個,依此類推,直到第n 1個與第n個比較為止,第一趟排序完後,記錄最大的關鍵字會被排在最後面。2.將記錄的前n 1個關鍵字進行第二趟比較交換,直到前n 1個中最...
排序演算法 氣泡排序
從基礎重新抓起。氣泡排序 每次從陣列頭到尾選出最大或者最小的,排到尾部或者頭部。以排序結果從小到大為例 每次從陣列中把最大的調換到末尾。eg.元素個數 count,需要找count 1次 外迴圈,最後一次不用再做比較了 每次從頭到末尾沒有確定的資料中找最大的 內迴圈 做法就是比較相鄰兩個元素的大小,...
排序演算法 氣泡排序
排序演算法 冒泡冒泡 從小到大排序 int a 5 a 0 a 1 a 2 a 3 a 4 5 4 3 2 1 4 3 2 1 5 第一輪比較 從a 0 開始依次拿相鄰兩個數比較 如果前面的大於後面的 a j a j 1 那麼兩個數交換 3 2 1 4 5 第二輪比較,從a 0 開始依次拿相鄰兩個數...