python實現冒泡演算法

2021-09-13 11:51:31 字數 864 閱讀 5031

- 演算法思想: 每次比較兩個相鄰的元素, 如果他們的順序錯誤就把他們交換位置

比如有五個數: 12, 35, 99, 18, 76, 從大到小排序, 對相鄰的兩位進行比較

第一趟:

第一次比較: 35, 12, 99, 18, 76

第二次比較: 35, 99, 12, 18, 76

第三次比較: 35, 99, 18, 12, 76

第四次比較: 35, 99, 18, 76, 12

經過第一趟比較後, 五個數中最小的數已經在最後面了, 接下來只比較前四個數, 依次類推

第二趟99, 35, 76, 18, 12

第三趟99, 76, 35, 18, 12

第四趟99, 76, 35, 18, 12

比較完成

氣泡排序原理: 每一趟只能將乙個數歸位, 如果有n個數進行排序,只需將n-1個數歸位, 也就是說要進行n-1趟操作(已經歸位的數不用再比較)

def bubble(numbers):

for i in range(len(numbers)-1):

for j in range(len(numbers)-i-1):

if numbers[j] > numbers[j+1]:

numbers[j], numbers[j+1] = numbers[j+1], numbers[j]

return numbers

l = [2, 3, 44, 6, 2, 21, 3, 5, 7, 9]

print(bubble(l))

回頭看看基礎,資料結構和演算法還是很重要的,,,,,,,,,,,,,,,,,,,,,摸摸自己的頭頂,,,一陣嘆息!!!

python實現冒泡演算法

bubblesort.py 氣泡排序的實現 author xiaozhi date 2019 08 03 lista 34,19,20,30,10,5,88,40 for i in range len lista 1 交換輪次,數的個數減1 for j in range len lista 1 每乙...

Python實現氣泡排序演算法

第一天學習python寫的程式,函式和控制語句沒有括號總感覺有頭沒尾怪怪的,寫長了會不會連語句在什麼控制流裡都搞蒙了呢?coding utf 8 氣泡排序演算法 def bubble sort list,n exchange n 1 while exchange 0 bound exchange e...

python實現冒泡演算法排序

第一篇部落格就以冒泡演算法作為先行者吧。冒泡演算法通俗一點的理解就是兩個數值進行比較,它重複地遍歷要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。遍歷數列的工作是重複地進行直到沒有再需要交換,也就是說該數列已經排序完成,就像小魚吐泡泡一樣。氣泡排序演算法具體的步驟大致為 降序為例...