什么是冒泡排序?
冒泡排序(Bubble Sort),是一種計算機科學領域的較簡單的排序算法。
它重復地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重復地進行直到沒有再需要交換,也就是說該數列已經排序完成。
這個算法的名字由來是因為越大的元素會經由交換慢慢“浮”到數列的頂端,故名冒泡排序。
以上是百度詞條對冒泡排序的官方解釋。
但是我要說一下我的個人理解,我覺得冒泡排序的核心思想是:每次比較兩個數,如果他們順序錯誤(大于或者小于),那么就把他們置換。
例如:如果要將五個無序的數字做升序排列(也就是從小到大排列),那么利用冒泡排序如何實現呢?
以上就是冒泡排序的實現思路,接下來看代碼!
如何實現?
到底該怎么實現呢?看了上面的分析,我相信你也能編出來吧!
看下我用python/286650.html">python編的吧:
方法一:常規實現冒泡排序
# 方法1# 定義一個列表,用于存放數字list = []while True: # 自定義輸入數字個數 print('你想排列幾個數?') try: num = int(input()) for i in range(num): a = int(input('請輸入第' + str((i+1)) + '個整數:')) list.append(a) except ValueError: print('輸入有誤!') # 冒泡排序核心代碼, for j in range(len(list)-1): for k in range(len(list)-1): if list[k] < list[k+1]: t = list[k] list[k] = list[k+1] list[k+1] = t print(list)算法的優劣主要看它的時間復雜度,冒泡排序的時間復雜度為:O(N^2)
可以看出,冒泡排序的時間復雜度偏高,所以它還不是最優算法!
方法二:利用sorted()方法快速實現排序
# 定義一個列表對象存數字list = []print('你想排列幾個數?')try: num = int(input()) for i in range(num): a = int(input('請輸入第' + str((i + 1)) + '個整數:')) list.append(a)except ValueError: print('輸入有誤!')# 利用sorted()方法排序,并使用reverse字段實現降序print(sorted(list, reverse=True))非常推薦這種利用sorted()方法實現排序的方法,因為簡單嘛!python就是以簡潔為名,越少的代碼實現相同的功能,何樂而不為!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答