資料結構32:選擇排序
選擇排序Selection Sort
選擇排序對氣泡排序進行了改進,保留了其基本的多趟對比的思路,每趟都使當前最大項就位。
但是選擇排序對交換進行了削弱,每趟僅進行一次交換,記錄最大項的所在位置,最後再跟本趟最後一項進行交換。
選擇排序的時間複雜度比氣泡排序稍優。
對比次數不變,還是O(n^2)
交換次數減少,為O(n)
def selectSort(alist):
for fillslot in range(len(alist)-1, 0, -1):
positionOfMax = 0
for location in range(1, fillslot+1):
if alist[location] > alist[positionOfMax]:
positionOfMax = location
temp = alist[fillslot]
alist[fillslot] = alist[positionOfMax]
alist[positionOfMax] = temp
return alist
相關文章
- 資料結構與演算法——排序演算法-選擇排序資料結構演算法排序
- 演算法與資料結構——選擇排序(c++)演算法資料結構排序C++
- 資料結構學習筆記-簡單選擇排序資料結構筆記排序
- 【圖解資料結構】 一組動畫演示選擇排序圖解資料結構動畫排序
- 資料結構和演算法:03.冒泡、選擇排序資料結構演算法排序
- 重學資料結構和演算法(四)之氣泡排序、插入排序、選擇排序資料結構演算法排序
- 演算法與資料結構系列 ( 三 ) - 選擇排序法- Select Sort演算法資料結構排序
- python演算法與資料結構-氣泡排序(32)Python演算法資料結構排序
- 看圖輕鬆理解資料結構與演算法系列(選擇排序)資料結構演算法排序
- 從零開始學資料結構和演算法(一)冒泡與選擇排序資料結構演算法排序
- 資料結構與排序資料結構排序
- 選擇結構
- 選擇排序排序
- 順序結構與選擇結構
- 資料結構之計數排序資料結構排序
- 資料結構第10章 排序資料結構排序
- 資料結構(python) —— 【18排序: 桶排序】資料結構Python排序
- switch選擇結構使用
- python的選擇結構Python
- 選擇排序和快速排序排序
- 冒泡、選擇、快排、插入排序—效能簡單測試/rand()邊界值——c++資料結構排序C++資料結構
- js選擇排序JS排序
- 01選擇排序排序
- 選擇排序法排序
- Java 選擇排序Java排序
- 資料結構--排序--插入排序--python語言描述資料結構排序Python
- 選擇排序中交換資料的不同方式出現的不同結果排序
- 資料結構與演算法——排序資料結構演算法排序
- 資料結構第九節(排序(上))資料結構排序
- 單連結串列的排序(插入,選擇,冒泡)排序
- 排序演算法:選擇排序排序演算法
- 排序演算法__選擇排序排序演算法
- 選擇排序和氣泡排序排序
- 氣泡排序與選擇排序排序
- 桶排序 選擇,插入排序排序
- Day12-if選擇結構
- 選擇結構程式設計程式設計
- C語言-選擇結構C語言