簡單選擇排序,就是每次從待排序的序列選出乙個最小值。
**思想。首先指標q指向煉表頭,當鍊表不為空,向後移動。將第乙個元素設為min,最小值,同時設定乙個標記指標s,令s=q;
下面進行的是將後面n-1個看成乙個待排序序列,如果出現比min小的就交換到第乙個,此次從q->next開始,p=q->next,當p不為null,向後遍歷。如果出現min>p指標所指向的結點的資料域裡面的資料,那麼最小值就是p->data,此次s更新標記p;直到p的一輪遍歷結束,此時,判斷s的值於初始值q是否一致,如果不一致,說明發生了min的更改,此時s指向的記錄就是真實最小值,設定t來交換min和q的資料域。這時,第乙個位置就是第一輪的最小值,這一輪結束,下面進行q->next,進行下一輪,直到遍歷至q=0結束,每一次都滿足選取最小值依次實現遞增排序。
簡單選擇排序 簡單選擇排序詳解
n個記錄的檔案的直接選擇排序可經過n 1趟直接選擇排序得到有序結果 初始狀態 無序區為r 1.n 有序區為空。第1趟排序 在無序區r 1.n 中選出關鍵字最小的記錄r k 將它與無序區的第1個記錄r 1 交換,使r 1.1 和r 2.n 分別變為記錄個數增加1個的新有序區和記錄個數減少1個的新無序區...
選擇排序 簡單選擇排序
在要排序的一組數中,選出最小 或者最大 的乙個數與第1個位置的數交換 然後在剩下的數當中再找最小 或者最大 的與第2個位置的數交換,依次類推,直到第n 1個元素 倒數第二個數 和第n個元素 最後乙個數 比較為止。第一趟,從n個記錄中找出關鍵碼最小的記錄與第乙個記錄交換 第二趟,從第二個記錄開始的n ...
選擇排序 簡單選擇排序
1.選擇排序 簡單選擇排序,堆排序 與交換排序 氣泡排序,快速排序 的區別 每次比較如果發現較小的元素在後面,就交換兩個相鄰的元素。而選擇排序演算法的改進在於 先並不急於調換位置,先從a 1 開始逐個檢查,看哪個數最小就記下該數所在的位置p,等一躺掃瞄完畢,再把a p 和a 1 對調,這時a 1 到...