国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python實現冒泡排序算法的兩種方法

2020-01-04 15:43:41
字體:
來源:轉載
供稿:網友

什么是冒泡排序?

冒泡排序(Bubble Sort),是一種計算機科學領域的較簡單的排序算法。

它重復地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重復地進行直到沒有再需要交換,也就是說該數列已經排序完成。

這個算法的名字由來是因為越大的元素會經由交換慢慢“浮”到數列的頂端,故名冒泡排序。

以上是百度詞條對冒泡排序的官方解釋。

但是我要說一下我的個人理解,我覺得冒泡排序的核心思想是:每次比較兩個數,如果他們順序錯誤(大于或者小于),那么就把他們置換。

例如:如果要將五個無序的數字做升序排列(也就是從小到大排列),那么利用冒泡排序如何實現呢?

  1. 首先,比較第一個數和第二個數的大小,由于是從小到大排列,所以如果第一個數大于第二個數,則將這兩個數互換位置,反之則不變。
  2. 然后進行第二個數和第三個數比較,同上。
  3. 這樣依次比較一輪后,你會發現,總共比了4次,也就是說,如果有n個數進行比較,那么需要n-1次才能完成。
  4. 上面過程主要完成了一輪比較,最終確定了一個最大的數,并且排在5個數的最后,也就是第五個數。
  5. 那么也就意味著需要在進行第一個數到第四個數的一輪比較,確定最大值。
  6. 接著從第一個數到第三個數......
  7. 這樣規律就很明顯了,五個數需要比較四輪,就能將5個數升序排列,所以n個數需要比較n-1輪。

以上就是冒泡排序的實現思路,接下來看代碼!

如何實現?

到底該怎么實現呢?看了上面的分析,我相信你也能編出來吧!

看下我用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武林網。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 贺兰县| 吉水县| 石河子市| 磴口县| 怀远县| 乡宁县| 仁怀市| 闽侯县| 公主岭市| 肥西县| 民丰县| 东至县| 夏河县| 兴隆县| 随州市| 鄂尔多斯市| 土默特左旗| 聊城市| 平果县| 儋州市| 满洲里市| 宣汉县| 青田县| 铜陵市| 石泉县| 天长市| 嘉祥县| 濮阳市| 额尔古纳市| 通许县| 永靖县| 望奎县| 铜梁县| 若尔盖县| 汉川市| 荆州市| 盱眙县| 紫阳县| 神池县| 安图县| 伊川县|