日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python數據結構的排序算法

瀏覽:44日期:2022-08-06 15:31:44
目錄十大經典的排序算法 一、交換排序1、冒泡排序(前后比較-交換)2、快速排序(選取一個基準值,小數在左大數在右)二、插入排序1、簡單插入排序(逐個插入到前面的有序數中)2、希爾排序(從大范圍到小范圍進行比較-交換)三、選擇排序1、簡單選擇排序(選擇最小的數據放在前面) 2、堆排序(利用最大堆和最小堆的特性)四、歸并排序 五、其他排序1、計數排序(字典計數-還原)2、桶排序(鏈表)3、基數排序十大經典的排序算法

數據結構中的十大經典算法:冒泡排序、快速排序、簡單插入排序、希爾排序、簡單選擇排序、堆排序、歸并排序、計數排序、桶排序、基數排序

十大經典算法的復雜度和穩定性(如果a原本在b前面,而a=b,排序之后a仍然在b的前面):

python數據結構的排序算法

一、交換排序1、冒泡排序(前后比較-交換)

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

python數據結構的排序算法

(2)python實現代碼

def bubble_sort(blist): count = len(blist) for i in range(0, count):for j in range(i + 1, count): if blist[i] > blist[j]:blist[i], blist[j] = blist[j], blist[i] return blist2、快速排序(選取一個基準值,小數在左大數在右)

(1)算法思想找基準數,通過一趟排序將要排序的數據分割成獨立的兩部分,其中一部分的所有數據都比另外一部分的所有數據都要小,然后再按此方法對這兩部分數據分別進行快速排序,整個排序過程可以遞歸進行,以此達到整個數據變成有序序列

python數據結構的排序算法

(2)python實現代碼

def quick_sort(qlist): if qlist == []:return [] else:qfirst = qlist[0]qless = quick_sort([l for l in qlist[1:] if l < qfirst])qmore = quick_sort([m for m in qlist[1:] if m >= qfirst])return qless + [qfirst] + qmore二、插入排序1、簡單插入排序(逐個插入到前面的有序數中)

(1)算法思想插入排序的基本操作就是將一個數據插入到已經排好序的有序數據中,從而得到一個新的、個數加一的有序數據,算法適用于少量數據的排序;首先將第一個作為已經排好序的,然后每次從后的取出插入到前面并排序

python數據結構的排序算法

(2)python實現代碼

(2)python實現代碼def insert_sort(ilist): for i in range(len(ilist)):for j in range(i): if ilist[i] < ilist[j]:ilist.insert(j, ilist.pop(i))break return ilist2、希爾排序(從大范圍到小范圍進行比較-交換)

(1)算法思想先取一個正整數 d1,以 d1 間隔分組,先對每個分組內的元素使用插入排序操作,重復上述分組和直接插入排序操作;直至 di = 1,即所有記錄放進一個組中排序為止。

python數據結構的排序算法

(2)python實現代碼

def shell_sort(slist): gap = len(slist) while gap > 1:gap = gap // 2for i in range(gap, len(slist)): for j in range(i % gap, i, gap):if slist[i] < slist[j]: slist[i], slist[j] = slist[j], slist[i] return slist三、選擇排序1、簡單選擇排序(選擇最小的數據放在前面)

(1)算法思想第1趟,在待排序記錄r1 ~ r[n]中選出最小的記錄,將它與r1交換;第2趟,在待排序記錄r2 ~ r[n]中選出最小的記錄,將它與r2交換;以此類推,第i趟在待排序記錄r[i] ~ r[n]中選出最小的記錄,將它與r[i]交換,使有序序列不斷增長直到全部排序完畢

python數據結構的排序算法

(2)python實現代碼

def select_sort(slist): for i in range(len(slist) - 1):x = ifor j in range(i, len(slist)): if slist[j] < slist[x]:x = jslist[i], slist[x] = slist[x], slist[i] return slist 2、堆排序(利用最大堆和最小堆的特性)

(1)算法思想它是選擇排序的一種。可以利用數組的特點快速定位指定索引的元素。堆分為大根堆和小根堆,是完全二叉樹。大根堆的要求是每個節點的值都不大于其父節點的值。在數組的非降序排序中,需要使用的就是大根堆,因為根據大根堆的要求可知,最大的值一定在堆頂

python數據結構的排序算法

(2)python實現代碼

import math def heap_sort(a): al = len(a) def heapify(a, i):left = 2 * i + 1right = 2 * i + 2largest = iif left < al and a[left] > a[largest]: largest = leftif right < al and a[right] > a[largest]: largest = rightif largest != i: a[i], a[largest] = a[largest], a[i] heapify(a, largest) # 建堆 for i in range(math.floor(len(a) / 2), -1, -1):heapify(a, i) # 不斷調整堆:根與最后一個元素 for i in range(len(a) - 1, 0, -1):a[0], a[i] = a[i], a[0]al -= 1heapify(a, 0) return a四、歸并排序

(1)算法思想采用分治法(Divide and Conquer)的一個非常典型的應用。將已有序的子序列合并,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序。若將兩個有序表合并成一個有序表,稱為二路歸并

python數據結構的排序算法

(2)python實現代碼

def merge_sort(a): if(len(a)<2):return a middle = len(a)//2 left, right = a[0:middle], a[middle:] return merge(merge_sort(left), merge_sort(right)) def merge(left,right): result = [] while left and right:if left[0] <= right[0]: result.append(left.pop(0));else: result.append(right.pop(0)); while left:result.append(left.pop(0)); while right:result.append(right.pop(0)); return result 五、其他排序1、計數排序(字典計數-還原)

(1)算法思想計數排序的核心在于將輸入的數據值轉化為鍵存儲在額外開辟的數組空間中。作為一種線性時間復雜度的排序,計數排序要求輸入的數據必須是有確定范圍的整數。

python數據結構的排序算法

(2)python實現代碼

def countingSort(arr, maxValue): bucketLen = maxValue+1 bucket = [0]*bucketLen sortedIndex =0 arrLen = len(arr) for i in range(arrLen):if not bucket[arr[i]]: bucket[arr[i]]=0bucket[arr[i]]+=1 for j in range(bucketLen):while bucket[j]>0: arr[sortedIndex] = j sortedIndex+=1 bucket[j]-=1 return arr2、桶排序(鏈表)

(1)算法思想為了節省空間和時間,我們需要指定要排序的數據中最小以及最大的數字的值。將數組分到有限數量的桶子里。每個桶子再個別排序(有可能再使用別的排序算法或是以遞歸方式繼續使用桶排序進行排序)

python數據結構的排序算法

(2)python實現代碼

def bucketSort(nums): bucket=[0]*(max(nums)-min(nums)+1) for i in range(len(nums)):bucket[nums[i]-min(nums)]+=1 tmp=[] for i in range(len(bucket)):if bucket[i]!=0: tmp+=[min(nums)+i]*bucket[i] return tmp3、基數排序

(1)算法思想基數排序將數據按位進行分桶,然后將桶中的數據合并。每次分桶只關注其中一位數據,其他位的數據不管,最大的數據有多少位,就進行多少次分桶和合并。由于整數也可以表達字符串(比如名字或日期)和特定格式的浮點數,所以基數排序也不是只能使用于整數。

python數據結構的排序算法

(2)python實現代碼

def radix_sort(array): bucket, digit = [[]], 0 while len(bucket[0]) != len(array):bucket = [[], [], [], [], [], [], [], [], [], []]for i in range(len(array)): num = (array[i] // 10 ** digit) % 10 bucket[num].append(array[i])array.clear()for i in range(len(bucket)): array += bucket[i]digit += 1 return array

以上就是python數據結構的排序算法的詳細內容,更多關于python數據結構的資料請關注好吧啦網其它相關文章!,希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
蜜臀国产一区| 日韩av福利| 亚洲精品第一| 日韩精品国产精品| 欧美一级网站| 日本黄色精品| 免费国产自久久久久三四区久久| re久久精品视频| 综合国产在线| 日韩视频1区| 久久亚州av| 亚洲精品网址| 日韩精品第一| av在线日韩| 中文字幕亚洲在线观看| 国产精品极品在线观看| 99精品综合| 久久精品 人人爱| 久久人人精品| 欧美日一区二区三区在线观看国产免| av日韩中文| 日韩精品五月天| 成人看片网站| 国产午夜久久av| 日韩三区在线| 国产麻豆一区二区三区精品视频| 九九精品调教| 国产精品调教视频| 丝袜美腿成人在线| 国产一二在线播放| 青草国产精品| 亚洲欧美网站| 高清日韩欧美| 国产精品一区二区av日韩在线| 最新亚洲一区| 伊伊综合在线| 亚洲网址在线观看| 国产美女撒尿一区二区| 中文另类视频| 亚洲一区久久| 91精品一区国产高清在线gif| 欧美亚洲网站| 亚洲专区视频| 日韩精品一级中文字幕精品视频免费观看 | 日韩极品在线观看| 极品日韩av| 色网在线免费观看| 国产一区二区三区四区| 国产精品一区二区av日韩在线| 在线精品视频一区| 亚洲欧美日本日韩| 怡红院精品视频在线观看极品| 日韩不卡在线| 久久久久久黄| 国产99久久| 欧美va亚洲va日韩∨a综合色| 亚洲精品**中文毛片| 成人亚洲一区| 久久国产亚洲| 丝袜美腿诱惑一区二区三区| 久久九九国产| 亚洲一区二区成人| 日韩一区二区三区精品| 国产日韩中文在线中文字幕 | 久久99精品久久久野外观看| 麻豆成人在线观看| 精品国产一级| 日韩精品中文字幕第1页| 欧美sm一区| 久久精品导航| 亚洲精品动态| 国产精品亚洲产品| 国产精品亚洲一区二区三区在线观看| 99精品综合| 综合激情一区| av资源新版天堂在线| 国产二区精品| 日韩av电影一区| 黄色在线观看www| 日韩在线一区二区| 国产精品久久久久久久久免费高清| 国产一区二区三区不卡视频网站 | 日韩福利视频网| 久久不卡国产精品一区二区| 国产精品一国产精品k频道56| 国产精品一卡| 婷婷激情图片久久| 欧美韩一区二区| 99香蕉国产精品偷在线观看| 国产精品极品在线观看| 黄色不卡一区| 嫩呦国产一区二区三区av| 亚洲精品一二三区区别| 欧美国产中文高清| 亚洲午夜91| 麻豆国产精品| 亚洲bt欧美bt精品777| 日韩成人亚洲| 国产专区精品| 国产一级成人av| 视频一区欧美日韩| 999国产精品永久免费视频app| 91成人在线| 亚洲综合婷婷| 久久成人亚洲| 自拍日韩欧美| 伊人久久大香线蕉av不卡| 精品一区二区三区免费看 | 中文字幕一区二区三区四区久久| 国产精品国产一区| 久久99蜜桃| 国产精品天天看天天狠| 日本亚洲不卡| 亚洲精品一二三**| 一区二区电影| 亚洲久久一区| 日本伊人久久| 国产三级精品三级在线观看国产| 亚洲精品美女| 91嫩草精品| 亚洲三级国产| 免费在线观看日韩欧美| 巨乳诱惑日韩免费av| 首页欧美精品中文字幕| 蜜臀va亚洲va欧美va天堂| 99xxxx成人网| 日av在线不卡| 日韩国产一二三区| 国产精品一在线观看| 国产精品极品国产中出| 国产成人免费av一区二区午夜| 精品伊人久久| 色偷偷偷在线视频播放| 国精品一区二区| 欧美综合国产| 日韩高清一区| 国产日韩在线观看视频| 成人三级高清视频在线看| 欧美 日韩 国产一区二区在线视频| 视频一区中文| 欧美一区成人| 成人日韩在线| 日本亚洲视频| 国产伦久视频在线观看| 亚洲激情黄色| 国产精品视频一区视频二区| 国产白浆在线免费观看| 欧美成人午夜| 国产精品一区亚洲| 色综合www| 日本不卡一区二区| 日本精品黄色| 亚洲+小说+欧美+激情+另类| 精品在线网站观看| 亚洲在线成人| 国产成人1区| 中文字幕免费精品| 亚洲涩涩在线| 国产日韩中文在线中文字幕| 日韩成人亚洲| 老司机免费视频一区二区| 在线一区免费观看| 国产一区二区三区四区大秀| 亚洲一区av| 免费av一区二区三区四区| 国产日产精品_国产精品毛片 | 一区二区三区午夜视频| 韩国久久久久久| 国产伦一区二区三区| 水野朝阳av一区二区三区| 欧洲一区二区三区精品| 国产精久久久| 日韩高清不卡一区二区| 亚洲欧美日韩在线观看a三区 | 麻豆视频一区| 欧美一区自拍| 免费精品视频最新在线| 国产盗摄——sm在线视频| 欧美国产专区| 久久精品欧洲| 国产激情一区| 国产精品亚洲四区在线观看 | 美女精品久久| 国产日韩精品视频一区二区三区| 亚洲一区导航| 亚洲一二av| 日韩精品欧美大片| 一级欧美视频| 亚洲日本国产| 婷婷综合电影| 奇米777国产一区国产二区| 婷婷成人av| 欧美伊人久久| 国产精品久久久久久av公交车| 欧美日韩 国产精品| 国产欧美日韩综合一区在线播放| 欧美日本二区| 久久影院午夜精品| 米奇777超碰欧美日韩亚洲| 亚洲国产日韩欧美在线|