首頁 >後端開發 >Python教學 >分享Python實作選擇排序的實例教程

分享Python實作選擇排序的實例教程

零下一度
零下一度原創
2017-06-19 15:35:441345瀏覽

選擇法也算是入門的一種排序演算法,比起冒泡法,它的方法巧妙了一些,它的出發點在於“挑”,每次挑選數組的最值,與前置元素換位,然後繼續挑選剩餘元素的最值並重複操作。個人認為選擇排序的意義不在於排序本身,而在於挑選和置換的方法,對於一些問題很有幫助。

選擇排序:

選擇排序(Selection sort)是一種簡單直覺的 排序演算法 。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然後,再從剩餘未排序元素中繼續尋找最小(大)元素,然後放到已排序序列的末端。以此類推,直到所有元素都排序完畢。 選擇排序的主要優點與資料移動有關。如果某個元素位於正確的最終位置上,則它不會被移動。選擇排序每次交換一對元素,它們當中至少有一個將被移到其最終位置上,因此對n個元素的表進行排序總共進行至多n-1次交換。在所有的完全依賴交換去移動元素的排序方法中,選擇排序屬於非常好的一種。

Python 實作:

 # selection_sort.py
 def selection_sort(arr):
   count = len(arr)
   for i in range(count-1):  # 交换 n-1 次
     min = i
     # 找最小数
     for j in range(i, count):
       if arr[min] > arr[j]:
         min = j
     arr[min], arr[i] = arr[i], arr[min]  # 交换
   return arr
 
 my_list = [6, 23, 2, 54, 12, 6, 8, 100]
 print(selection_sort(my_list))

以上是分享Python實作選擇排序的實例教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn