Python實現(xiàn)冒泡排序算法的完整實例
冒泡排序:顧名思義就是(較小的值)像泡泡一樣往上冒,(大的值)往下沉。
實現(xiàn)原理:依次將相鄰兩個數(shù)值進行比較,較小的數(shù)值移到左邊,較大的數(shù)值移到右邊,依次比較完第一輪后,最大的數(shù)值應(yīng)該排在最右邊。然后再繼續(xù)重復(fù)的比較,直至無數(shù)值需要交換,此時排序完成。
例子解釋:
無序列表arr = [7,6,5,3,9,2,8,1,4]
數(shù)列長度:len = 9
第一趟排序:
i = 1;
arr = [7,6,5,3,9,2,8,1,4]
- 7>6 =>[6,7,5,3,9,2,8,1,4]數(shù)值小的放左邊,數(shù)值打的放右邊
- 7>5 =>[6,5,7,3,9,2,8,1,4]
- 7>3 =>[6,5,3,7,9,2,8,1,4]
- 7<9 =>[6,5,3,7,9,2,8,1,4]
- 9>2 =>[6,5,3,7,2,9,8,1,4]
- 9>8 =>[6,5,3,7,2,8,9,1,4]
- 9>1 =>[6,5,3,7,2,8,1,9,4]
- 9>4 =>[6,5,3,7,2,8,1,4,9]
第一趟進行了8次交換,即子循環(huán)比較的次數(shù)為j=len-i=9-1=8
至此第一趟冒泡已完成,最大數(shù)值9已經(jīng)排到最右邊。
第二趟排序:
i = 2
arr = [6,5,3,7,2,8,1,4,9]
- 6>5 => [5,6,3,7,2,8,1,4,9]
- 6>3 => [5,3,6,7,2,8,1,4,9]
- 6<7 =>[5,3,6,7,2,8,1,4,9]
- 7>2 =>[5,3,6,2,7,8,1,4,9]
- 7<8 =>[5,3,6,2,7,8,1,4,9]
- 8>1 =>[5,3,6,2,7,1,8,4,9]
- 8>4 =>[5,3,6,2,7,1,4,8,9]
第二趟進行了7次交換,即子循環(huán)比較的次數(shù)為j=len-i=9-2=7
至此第二趟冒泡已完成,arr = [5,3,6,2,7,1,4,8,9]。
。。。
接下來也是如此依次比較排序,直至數(shù)組arr = [1,2,3,4,5,6,7,8,9]
總共進行了8趟排序;
Python代碼實現(xiàn):
def bubbleSort(arr):
# 獲取數(shù)組長度
arr_len = len(arr)
# 外部大循環(huán)=》第幾趟
for i in range(1, arr_len):
# 內(nèi)部循環(huán)比較=》相鄰數(shù)值進行比較
for j in range(0, arr_len - i):# 每次內(nèi)循環(huán)的次數(shù)都需要總長度減去已排好位置的值的數(shù)量
if arr[j] > arr[j+1]: # 左右比較
arr[j], arr[j+1] = arr[j+1], arr[j] # 將數(shù)值大的放右邊,數(shù)值小的放左邊
arr = [64, 34, 25, 12, 22, 11, 90]
bubbleSort(arr)
print('排序后:')
for i in range(len(arr)):
print('%d'%arr[i], end=' ')
總結(jié)
到此這篇關(guān)于Python實現(xiàn)冒泡排序算法的文章就介紹到這了,更多相關(guān)Python實現(xiàn)冒泡排序算法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python如何統(tǒng)計函數(shù)調(diào)用的耗時
這篇文章主要為大家詳細介紹了如何使用Python實現(xiàn)統(tǒng)計函數(shù)調(diào)用的耗時,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04
Python實現(xiàn)實時數(shù)據(jù)采集新型冠狀病毒數(shù)據(jù)實例
在本篇文章里小編給大家整理了關(guān)于Python實現(xiàn)實時數(shù)據(jù)采集新型冠狀病毒數(shù)據(jù)實例內(nèi)容,有需要的朋友們可以學(xué)習(xí)參考下。2020-02-02
python aiohttp創(chuàng)建很多線程的問題及解決
這篇文章主要介紹了python aiohttp創(chuàng)建很多線程的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06
TensorFlow tf.nn.softmax_cross_entropy_with_logits的用法
這篇文章主要介紹了TensorFlow tf.nn.softmax_cross_entropy_with_logits的用法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04

