日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

用python排序算法_Python - 八大排序算法

發(fā)布時間:2023/12/4 python 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 用python排序算法_Python - 八大排序算法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1、序言

本文使用Python實現(xiàn)了一些常用的排序方法。文章結(jié)構(gòu)如下:

1.直接插入排序

2.希爾排序

3.冒泡排序

4.快速排序

5.簡單選擇排序

6.堆排序

7.歸并排序

8.基數(shù)排序

上述所有的排序均寫在一個Python自定義類中,作為成員函數(shù)。

2、排序方法詳細(xì)介紹

1.直接插入排序

直接插入排序(Straight Insertion Sort)是一種最簡單的排序方法,它的基本操作是一個值插入到已排好序的有序表中,從而得到一個新的、記錄數(shù)增1的有序表。如下圖所示:

由上圖可知若最初始的有序表即為數(shù)組的第一個元素。用Python實現(xiàn)如下:

defstraight_insertion_sort(self, value_list):"""直接插入排序

:param value_list: 無序列表

:return:"""

return self.__straight_insert(value_list)

@staticmethoddef __straight_insert(value_list):

sorted_list=[]

sorted_list.append(value_list.pop(0))for i inrange(0, len(value_list)):

tail= True #是否在尾部插入

insert_loc =0for j inrange(len(sorted_list)):if value_list[i] <=sorted_list[j]:

tail=False

insert_loc=jbreaksorted_list.append(value_list[i])#先將值插入尾部

if nottail:#移動值

for j in range(len(sorted_list) - 1, insert_loc, -1):

temp=sorted_list[j]

sorted_list[j]= sorted_list[j - 1]

sorted_list[j- 1] =tempreturn sorted_list

2.希爾排序

希爾排序(Shell’s Sort)又稱“縮小增量排序”(Diminishing Incerement Sort),它也是一種數(shù)插入排序的方法,但在時間效率上較前面的排序方法有較大的改進(jìn)。它的基本思想是:先將整個待排記錄序列分割成若干個子序列分別進(jìn)行直接插入排序,待整個序列中的記錄“基本有序”時,再對全體記錄進(jìn)行一次直接插入排序。如下圖所示:

即根據(jù)增量將原序列分割成多個子序列進(jìn)行直接插入排序。增量應(yīng)不斷減小,且最后一個增量為1。用Python實現(xiàn)如下:

defshells_sort(self, value_list):"""希爾排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""gap= len(value_list) // 2

while gap >= 1:

i=0while(i + gap)

start=i

gap_list=[]while start

gap_list.append(value_list[start])

start= start +gap

gap_list= self.__straight_insert(gap_list)

start=iwhile start

value_list[start]=gap_list.pop(0)

start+=gap

i+= 1gap//= 2sorted_list=value_listreturn sorted_list

3.冒泡排序

冒泡排序(Bubble Sort)的過程很簡單。首先將第一個記錄的關(guān)鍵字和第二個記錄的關(guān)鍵字進(jìn)行比較,若逆序(與需要的順序相反),則將兩個記錄交換之,然后比較第二個記錄和第三個記錄的關(guān)鍵字,以此類推。為第一趟冒泡結(jié)束,接著對前n-1個記錄繼續(xù)進(jìn)行上述的過程。這樣重復(fù)的過程直至n-1=1結(jié)束。排序過程如下所示:

用Python實現(xiàn)如下:

@staticmethoddefbubble_sort(value_list):"""冒泡排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""

for i in range(len(value_list) - 1):for j in range(i + 1, len(value_list)):if value_list[i] >value_list[j]:

value_list[i], value_list[j]=value_list[j], value_list[i]

sorted_list=value_listreturn sorted_list

4.快速排序

快速排序(Quick Sort)是對冒泡排序的一種改進(jìn)。它的基本思想是,通過一趟排序?qū)⒋庞涗浄指畛瑟毩⒌膬刹糠?#xff0c;其中一部分記錄的關(guān)鍵字均比另一部分記錄的關(guān)鍵字小,則可分別對這兩部分記錄繼續(xù)進(jìn)行排序,已達(dá)到整個序列有序。其排序思想如下:

首先任意選取一個記錄(通常可選第一個記錄)作為樞軸,然后按下述原則重新排列記錄:將所有關(guān)鍵字較它小的記錄都安置在它的位置之前,將所有關(guān)鍵字較它大的記錄都安置在它的位置之后。一趟快速排序的具體做法是:設(shè)兩個指針low和high,他們的初值分別為最低位置的下一個位置和最高位,設(shè)最低位置樞軸的關(guān)鍵字為pivotkey,則首先從high所指位置起向前搜索找到第一個關(guān)鍵字小于pivotkey的記錄的樞軸記錄互相交換。發(fā)生了交換后才從low所指向的位置起向后搜索,找到第一個關(guān)鍵字大于pivotkey的記錄和樞軸記錄互相交換。重復(fù)這兩步直至low=how為止

如下圖所示:

特別要注意換方向的時機是發(fā)生了交換后,用Python實現(xiàn)如下:

defquick_sort(self, value_list):"""快速排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""low=0

high= len(value_list) - 1self.__qsort(value_list, low, high)

sorted_list=value_listreturnsorted_listdef __qsort(self, val_list, low, high):"""快速排序輔助函數(shù)

:param val_list: 無序列表

:param low: 低位

:param high: 高位

:return:"""

if low >=high:returnpivot_key=low

temp_low=pivot_key

temp_high=highwhile low

while low

temp=val_list[high]

val_list[high]=val_list[pivot_key]

val_list[pivot_key]=temp

pivot_key=highbreak #發(fā)生交換后,就換方向

else:

high-= 1

while low val_list[pivot_key]:

temp=val_list[low]

val_list[low]=val_list[pivot_key]

val_list[pivot_key]=temp

pivot_key=lowbreak #發(fā)生交換后,就換方向

else:

low+= 1self.__qsort(val_list, temp_low, pivot_key - 1)

self.__qsort(val_list, pivot_key + 1, temp_high)

5.簡單選擇排序

選擇排序(Selection Sort)是一種簡單直觀的排序算法。它的基本思想是:每一趟在n-i+1(i=1,2,...,n-1)個記錄中選取關(guān)鍵字最小的記錄作為有序序列中第i個記錄。簡單選擇排序:通過n-1次關(guān)鍵字的比較,從n-i+1個記錄中選出關(guān)鍵字最小的記錄,并和第i(1≤i≤n)個記錄交換之。如下圖所示:

用Python實現(xiàn)如下:

@staticmethoddefsimple_selection_sort(value_list):"""簡單選擇排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""

for i inrange(len(value_list)):

min_val= 9999999

for j inrange(i, len(value_list)):if min_val >value_list[j]:

min_val=value_list[j]

count= 0 #如果有多個相同的最小值

for j inrange(i, len(value_list)):if min_val ==value_list[j]:

value_list[j], value_list[i+ count] = value_list[i +count], value_list[j]

sorted_list=value_listreturn sorted_list

6.堆排序

堆排序(Heap Sort)是指利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計的一種排序算法。堆的定義如下:

n個元素的序列{k1,k2,...,kn}當(dāng)且僅當(dāng)滿足一下關(guān)系時,稱之為堆。

若將序列看成是一個完全二叉樹,則堆的含義表明,完全二叉樹中所有非終端節(jié)點均不大于(或不小于)其左、右孩子節(jié)點的值。由此,若序列是堆,則堆頂元素必為序列中的最小值(或最大值)。如下圖所示:

至此,我們可以給出堆排序的過程:若在輸出堆頂?shù)淖钚≈岛?#xff0c;使得剩余n-1個元素的序列又建成一個堆,則得到n個元素中的次小值。如此反復(fù)執(zhí)行,便能得到一個有序序列。

故整個堆排序可以大致分為兩個過程:

·將無序序列建成堆。

·輸出堆頂元素后,用類似建堆的方法調(diào)整堆。

如下兩個圖所示:

根據(jù)堆排序的特點總結(jié)出兩點注意事項:

1.利用把堆看成完全二叉樹的特點,用完全二叉樹的性質(zhì)解決算法問題。

2.建堆的過程是從樹種的最后一個非終端節(jié)點逆序開始調(diào)整的。

3.每調(diào)整一次需要檢查前后是否依然保持堆的特征。

本文利用了二叉樹的孩子兄弟表示法來生成二叉樹(堆)的。代碼如下:

classCldSibNode(object):"""私有內(nèi)部類:孩子兄弟二叉鏈表節(jié)點"""

def __init__(self, val):

self.value=val

self.child=None

self.sibling=Nonedefheap_sort(self, value_list):"""堆排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""sorted_list=[]

root_node=self.CldSibNode(None)

self.__child_sibling(root_node, value_list, 0)for ct in range(1, len(value_list) // 2 + 1): #建堆

self.__adjust_heap(root_node, len(value_list) // 2 + 1 - ct, 1)for i in range(1, len(value_list) + 1): #堆排序

sorted_list.append(root_node.value) #輸出堆頂元素

head =root_node

self.__shrink_heap(root_node, len(value_list) + 1 - i, 1, head)

self.__adjust_heap(root_node, 1, 1) #調(diào)整堆

returnsorted_listdef __child_sibling(self, node, value_list, ind):"""創(chuàng)建完全二叉樹的左孩子右兄弟二叉鏈表

:param node: 當(dāng)前節(jié)點

:param value_list: 待排序的無序列表

:param ind:

:return:"""

if ind >=len(value_list):returnnode.value=value_list[ind]if ind * 2 + 1

node.child= self.CldSibNode(None) #孩子

self.__child_sibling(node.child, value_list, ind * 2 + 1)if ind * 2 + 2

node.child.sibling= self.CldSibNode(None) #兄弟

self.__child_sibling(node.child.sibling, value_list, ind * 2 + 2)def __adjust_heap(self, root_node, last_ind, now_ind):if not root_node or not root_node.child: #不為空且有孩子

return

if now_ind ==last_ind:#需要調(diào)整的非終端節(jié)點

temp =root_node

cg=Falsewhiletemp.child:if temp.value >temp.child.value:

temp.value, temp.child.value=temp.child.value, temp.value

cg= True #發(fā)生交換

iftemp.child.sibling:if temp.value >temp.child.sibling.value:ifcg:#如果發(fā)生過交換

temp.value, temp.child.value =temp.child.value, temp.value

temp.value, temp.child.sibling.value=temp.child.sibling.value, temp.value

temp=temp.child.siblingcontinue

else:ifcg:#如果發(fā)生過交換

temp =temp.childcontinue

break

#遞歸

self.__adjust_heap(root_node.child, last_ind, now_ind * 2)ifroot_node.child.sibling:

self.__adjust_heap(root_node.child.sibling, last_ind, now_ind * 2 + 1)def __shrink_heap(self, root_node, last_ind, now_ind, head):if not root_node or now_ind * 2 >last_ind:#為空

return

if last_ind == now_ind * 2 + 1:

head.value=root_node.child.sibling.value

root_node.child.sibling=NonereturnTrueif last_ind == now_ind * 2:

head.value=root_node.child.value

root_node.child=NonereturnTrueifroot_node.child:

self.__shrink_heap(root_node.child, last_ind, now_ind * 2, head)

self.__shrink_heap(root_node.child.sibling, last_ind, now_ind * 2 + 1, head)

7.歸并排序

歸并排序(Merging Sort),“歸并”的含義是將兩個或兩個以上的有序表組合成一個新的有序表。假設(shè)初始序列有n個記錄,則可看成是n個有序的子序列,每個子序列的長度為1,然后兩兩歸并,得到[n/2]個長度為2或1的有序子序列;再兩兩歸并,……,如此重復(fù),直至得到一個長度為n的有序序列為止,這種排序方法為2-路歸并排序。算法的基本思想如下圖所示:

其中兩個子序列的合并大有學(xué)問,基本思想就是:分別在兩個序列頭設(shè)置指針,比較兩個序列指針?biāo)傅闹档拇笮?#xff0c;將滿足要求的值提取出來形成新列表,并將指針右移。當(dāng)其中一個指針指向結(jié)尾之后時,表示其中一個列表已取盡,接著直接在新列表尾部連接另一個列表。如下圖所示:

用Python實現(xiàn)如下:

@staticmethoddefmerging_sort(self, value_list):"""歸并排序

:param value_list: 待排序的無序列表

:return: 排序后的新列表"""i=0while np.power(2, i)

count= np.power(2, i)

start=0

outer_temp=[]while start

other = start +count

temp=[]if other >=len(value_list):#另一邊不存在:直接合并

outer_temp.extend(value_list[start: start +count])breakleft, right=0, 0while left < count or right =len(value_list):#右邊提前結(jié)束

temp.extend(value_list[start + left: start +count])break

elif value_list[start + left] < value_list[other +right]:#左邊更小

temp.append(value_list[start +left])

left+= 1

if left ==count:#左邊遍歷結(jié)束

temp.extend(value_list[other + right: other +count])break

else:#右邊更小

temp.append(value_list[other +right])

right+= 1

if right ==count:#右邊遍歷結(jié)束

temp.extend(value_list[start + left: start +count])breakouter_temp.extend(temp)

start+= count * 2value_list=outer_temp

i+= 1sorted_list=value_listreturn sorted_list

8.基數(shù)排序

基數(shù)排序(Radix Sort)是一種非比較整數(shù)排序算法,其原理是將整數(shù)按位數(shù)切割成不同的數(shù)字,然后按每個位數(shù)分別比較。由于整數(shù)也可以表達(dá)字符串(比如名字或日期)和特定格式的浮點數(shù),所以基數(shù)排序也不是只能使用于整數(shù)。

排序時有兩點需要注意:

1.每完成一趟排序,要清空隊列。

2.隊列的連接要找到第一個不為空的隊列作為頭,和繞開所有空隊列。

用Python實現(xiàn)如下:

@staticmethoddefradix_sort(value_list):"""基數(shù)排序

:param value_list: 待排序的無序列表

:return: 排序后的新列表"""i=0

max_num=max(value_list)

n=len(str(max_num))while i

bucket_list = [[] for _ in range(10)]for x invalue_list:#找到位置放入桶數(shù)組

bucket_list[int(x / (10 ** i)) % 10].append(x)

value_list.clear()for x inbucket_list:#放回原序列

for y inx:

value_list.append(y)

i+= 1sorted_list=value_listreturn sorted_list

測試代碼:

編寫測試代碼運行結(jié)果如下:

if __name__ == '__main__':

li= list(np.random.randint(1, 1000, 30))

my_sort=MySort()print("original sequence:", li)print("*" * 100)print("1.straight_insertion_sort:", my_sort.straight_insertion_sort(li.copy()))print("2.shells_sort:", my_sort.shells_sort(li.copy()))print("3.bubble_sort:", my_sort.bubble_sort(li.copy()))print("4.quick_sort:", my_sort.quick_sort(li.copy()))print("5.simple_selection_sort:", my_sort.simple_selection_sort(li.copy()))print("6.heap_sort:", my_sort.heap_sort(li.copy()))print("7.merging_sort:", my_sort.merging_sort(li.copy()))print("8.radix_sort:", my_sort.radix_sort(li.copy()))

測試運行結(jié)果:

original sequence: [424, 381, 234, 405, 554, 742, 527, 876, 27, 904, 169, 566, 854, 448, 65, 508, 226, 477, 12, 670, 408, 520, 774, 99, 159, 565, 393, 288, 149, 711]****************************************************************************************************

1.straight_insertion_sort: [12, 27, 65, 99, 149, 159, 169, 226, 234, 288, 381, 393, 405, 408, 424, 448, 477, 508, 520, 527, 554, 565, 566, 670, 711, 742, 774, 854, 876, 904]2.shells_sort: [12, 27, 65, 99, 149, 159, 169, 226, 234, 288, 381, 393, 405, 408, 424, 448, 477, 508, 520, 527, 554, 565, 566, 670, 711, 742, 774, 854, 876, 904]3.bubble_sort: [12, 27, 65, 99, 149, 159, 169, 226, 234, 288, 381, 393, 405, 408, 424, 448, 477, 508, 520, 527, 554, 565, 566, 670, 711, 742, 774, 854, 876, 904]4.quick_sort: [12, 27, 65, 99, 149, 159, 169, 226, 234, 288, 381, 393, 405, 408, 424, 448, 477, 508, 520, 527, 554, 565, 566, 670, 711, 742, 774, 854, 876, 904]5.simple_selection_sort: [12, 27, 65, 99, 149, 159, 169, 226, 234, 288, 381, 393, 405, 408, 424, 448, 477, 508, 520, 527, 554, 565, 566, 670, 711, 742, 774, 854, 876, 904]6.heap_sort: [12, 27, 65, 99, 149, 159, 169, 226, 234, 288, 381, 393, 405, 408, 424, 448, 477, 508, 520, 527, 554, 565, 566, 670, 711, 742, 774, 854, 876, 904]7.merging_sort: [12, 27, 65, 99, 149, 159, 169, 226, 234, 288, 381, 393, 405, 408, 424, 448, 477, 508, 520, 527, 554, 565, 566, 670, 711, 742, 774, 854, 876, 904]8.radix_sort: [12, 27, 65, 99, 149, 159, 169, 226, 234, 288, 381, 393, 405, 408, 424, 448, 477, 508, 520, 527, 554, 565, 566, 670, 711, 742, 774, 854, 876, 904]

總結(jié)

各個排序效率見下圖:

可以得出以下幾個結(jié)論:

1.從平均時間性能而言,快速排序最佳。

2.堆排序適用于n較大的數(shù)據(jù)。

3.基數(shù)排序是穩(wěn)定的,時間復(fù)雜度較大的簡單排序方法也是穩(wěn)定的。

4.穩(wěn)定性是由方法本身決定的。

5.沒有最好的排序方法,視情況而定。

#! /usr/bin/env python3#-*- coding:utf-8 -*-

#Author : MaYi#Blog : http://www.cnblogs.com/mayi0312/#Date : 2020-01-06#Name : mySort#Software : PyCharm#Note : 八大排序算法

importnumpy as npclassMySort(object):"""自定義一個排序的類"""

defstraight_insertion_sort(self, value_list):"""直接插入排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""

return self.__straight_insert(value_list)

@staticmethoddef __straight_insert(value_list):

sorted_list=[]

sorted_list.append(value_list.pop(0))for i inrange(0, len(value_list)):

tail= True #是否在尾部插入

insert_loc =0for j inrange(len(sorted_list)):if value_list[i] <=sorted_list[j]:

tail=False

insert_loc=jbreaksorted_list.append(value_list[i])#先將值插入尾部

if nottail:#移動值

for j in range(len(sorted_list) - 1, insert_loc, -1):

sorted_list[j], sorted_list[j- 1] = sorted_list[j - 1], sorted_list[j]returnsorted_listdefshells_sort(self, value_list):"""希爾排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""gap= len(value_list) // 2

while gap >= 1:

i=0while(i + gap)

start=i

gap_list=[]while start

gap_list.append(value_list[start])

start= start +gap

gap_list= self.__straight_insert(gap_list)

start=iwhile start

value_list[start]=gap_list.pop(0)

start+=gap

i+= 1gap//= 2sorted_list=value_listreturnsorted_list

@staticmethoddefbubble_sort(value_list):"""冒泡排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""

for i in range(len(value_list) - 1):for j in range(i + 1, len(value_list)):if value_list[i] >value_list[j]:

value_list[i], value_list[j]=value_list[j], value_list[i]

sorted_list=value_listreturnsorted_listdefquick_sort(self, value_list):"""快速排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""low=0

high= len(value_list) - 1self.__qsort(value_list, low, high)

sorted_list=value_listreturnsorted_listdef __qsort(self, val_list, low, high):"""快速排序輔助函數(shù)

:param val_list: 無序列表

:param low: 低位

:param high: 高位

:return:"""

if low >=high:returnpivot_key=low

temp_low=pivot_key

temp_high=highwhile low

while low

temp=val_list[high]

val_list[high]=val_list[pivot_key]

val_list[pivot_key]=temp

pivot_key=highbreak #發(fā)生交換后,就換方向

else:

high-= 1

while low val_list[pivot_key]:

temp=val_list[low]

val_list[low]=val_list[pivot_key]

val_list[pivot_key]=temp

pivot_key=lowbreak #發(fā)生交換后,就換方向

else:

low+= 1self.__qsort(val_list, temp_low, pivot_key - 1)

self.__qsort(val_list, pivot_key + 1, temp_high)

@staticmethoddefsimple_selection_sort(value_list):"""簡單選擇排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""

for i inrange(len(value_list)):

min_val= 9999999

for j inrange(i, len(value_list)):if min_val >value_list[j]:

min_val=value_list[j]

count= 0 #如果有多個相同的最小值

for j inrange(i, len(value_list)):if min_val ==value_list[j]:

value_list[j], value_list[i+ count] = value_list[i +count], value_list[j]

sorted_list=value_listreturnsorted_listclassCldSibNode(object):"""私有內(nèi)部類:孩子兄弟二叉鏈表節(jié)點"""

def __init__(self, val):

self.value=val

self.child=None

self.sibling=Nonedefheap_sort(self, value_list):"""堆排序

:param value_list: 待排序的無序列表

:return: 排序后的列表"""sorted_list=[]

root_node=self.CldSibNode(None)

self.__child_sibling(root_node, value_list, 0)for ct in range(1, len(value_list) // 2 + 1): #建堆

self.__adjust_heap(root_node, len(value_list) // 2 + 1 - ct, 1)for i in range(1, len(value_list) + 1): #堆排序

sorted_list.append(root_node.value) #輸出堆頂元素

head =root_node

self.__shrink_heap(root_node, len(value_list) + 1 - i, 1, head)

self.__adjust_heap(root_node, 1, 1) #調(diào)整堆

returnsorted_listdef __child_sibling(self, node, value_list, ind):"""創(chuàng)建完全二叉樹的左孩子右兄弟二叉鏈表

:param node: 當(dāng)前節(jié)點

:param value_list: 待排序的無序列表

:param ind:

:return:"""

if ind >=len(value_list):returnnode.value=value_list[ind]if ind * 2 + 1

node.child= self.CldSibNode(None) #孩子

self.__child_sibling(node.child, value_list, ind * 2 + 1)if ind * 2 + 2

node.child.sibling= self.CldSibNode(None) #兄弟

self.__child_sibling(node.child.sibling, value_list, ind * 2 + 2)def __adjust_heap(self, root_node, last_ind, now_ind):if not root_node or not root_node.child: #不為空且有孩子

return

if now_ind ==last_ind:#需要調(diào)整的非終端節(jié)點

temp =root_node

cg=Falsewhiletemp.child:if temp.value >temp.child.value:

temp.value, temp.child.value=temp.child.value, temp.value

cg= True #發(fā)生交換

iftemp.child.sibling:if temp.value >temp.child.sibling.value:ifcg:#如果發(fā)生過交換

temp.value, temp.child.value =temp.child.value, temp.value

temp.value, temp.child.sibling.value=temp.child.sibling.value, temp.value

temp=temp.child.siblingcontinue

else:ifcg:#如果發(fā)生過交換

temp =temp.childcontinue

break

#遞歸

self.__adjust_heap(root_node.child, last_ind, now_ind * 2)ifroot_node.child.sibling:

self.__adjust_heap(root_node.child.sibling, last_ind, now_ind * 2 + 1)def __shrink_heap(self, root_node, last_ind, now_ind, head):if not root_node or now_ind * 2 >last_ind:#為空

return

if last_ind == now_ind * 2 + 1:

head.value=root_node.child.sibling.value

root_node.child.sibling=NonereturnTrueif last_ind == now_ind * 2:

head.value=root_node.child.value

root_node.child=NonereturnTrueifroot_node.child:

self.__shrink_heap(root_node.child, last_ind, now_ind * 2, head)

self.__shrink_heap(root_node.child.sibling, last_ind, now_ind * 2 + 1, head)

@staticmethoddefmerging_sort(value_list):"""歸并排序

:param value_list: 待排序的無序列表

:return: 排序后的新列表"""i=0while np.power(2, i)

count= np.power(2, i)

start=0

outer_temp=[]while start

other = start +count

temp=[]if other >=len(value_list):#另一邊不存在:直接合并

outer_temp.extend(value_list[start: start +count])breakleft, right=0, 0while left < count or right =len(value_list):#右邊提前結(jié)束

temp.extend(value_list[start + left: start +count])break

elif value_list[start + left] < value_list[other +right]:#左邊更小

temp.append(value_list[start +left])

left+= 1

if left ==count:#左邊遍歷結(jié)束

temp.extend(value_list[other + right: other +count])break

else:#右邊更小

temp.append(value_list[other +right])

right+= 1

if right ==count:#右邊遍歷結(jié)束

temp.extend(value_list[start + left: start +count])breakouter_temp.extend(temp)

start+= count * 2value_list=outer_temp

i+= 1sorted_list=value_listreturnsorted_list

@staticmethoddefradix_sort(value_list):"""基數(shù)排序

:param value_list: 待排序的無序列表

:return: 排序后的新列表"""i=0

max_num=max(value_list)

n=len(str(max_num))while i

bucket_list = [[] for _ in range(10)]for x invalue_list:#找到位置放入桶數(shù)組

bucket_list[int(x / (10 ** i)) % 10].append(x)

value_list.clear()for x inbucket_list:#放回原序列

for y inx:

value_list.append(y)

i+= 1sorted_list=value_listreturnsorted_listif __name__ == '__main__':

li= list(np.random.randint(1, 1000, 30))

my_sort=MySort()print("original sequence:", li)print("*" * 100)print("1.straight_insertion_sort:", my_sort.straight_insertion_sort(li.copy()))print("2.shells_sort:", my_sort.shells_sort(li.copy()))print("3.bubble_sort:", my_sort.bubble_sort(li.copy()))print("4.quick_sort:", my_sort.quick_sort(li.copy()))print("5.simple_selection_sort:", my_sort.simple_selection_sort(li.copy()))print("6.heap_sort:", my_sort.heap_sort(li.copy()))print("7.merging_sort:", my_sort.merging_sort(li.copy()))print("8.radix_sort:", my_sort.radix_sort(li.copy()))

完整代碼

總結(jié)

以上是生活随笔為你收集整理的用python排序算法_Python - 八大排序算法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

在线视频一区观看 | 最近中文字幕mv | 久久久国产精品一区二区中文 | 欧美乱码精品一区二区 | 国产一区二区在线观看视频 | 国产高清在线不卡 | 成人黄性视频 | 国产一区二区中文字幕 | 91精品久久久久久综合乱菊 | 四虎精品成人免费网站 | 久久免费观看少妇a级毛片 久久久久成人免费 | 在线国产精品视频 | 亚洲视频久久 | 在线视频福利 | 91av色 | 久久久国产精品亚洲一区 | 亚洲伦理精品 | 啪嗒啪嗒免费观看完整版 | 福利av影院 | 免费在线色 | 国产免费又粗又猛又爽 | 国产在线播放观看 | 九九精品毛片 | 香蕉看片| 久久久久国产精品www | 一区二区三区在线免费观看 | 久久视频国产精品免费视频在线 | 97在线看片 | 免费在线国产视频 | 亚洲aⅴ免费在线观看 | 国产精品视频永久免费播放 | 91人人爽人人爽人人精88v | 日韩在线视频免费看 | 国产成人免费av电影 | 色五月情| 国产欧美精品xxxx另类 | 黄色的网站在线 | 精品国产乱码久久久久久天美 | 国产成人精品免高潮在线观看 | 国产日产欧美在线观看 | 精品亚洲va在线va天堂资源站 | 午夜18视频在线观看 | 中文字幕在线观看一区二区三区 | 亚洲午夜精品久久久久久久久久久久 | 国产日韩精品在线观看 | 99在线观看免费视频精品观看 | 欧美性生活大片 | 99热精品视| 综合色综合 | 国产成人综合在线观看 | 视频二区在线视频 | 亚洲精品播放 | 久久久久成人精品免费播放动漫 | 丁香 久久 综合 | 日韩精品首页 | 麻豆影视在线观看 | 一级片视频免费观看 | 国产精品免费不卡 | 狠狠色免费| 麻花豆传媒mv在线观看 | 国产在线精品一区二区不卡了 | japanesexxxxfreehd乱熟 | 国产精品久久久久久影院 | 日韩电影一区二区在线观看 | 欧美国产日韩激情 | 人人干干人人 | 中文免费观看 | 美女视频久久 | 国内精品久久久久久久 | 久久精选 | 国产精品不卡一区 | 在线视频一区二区 | 在线观看av的网站 | 久久第四色 | www99精品| 精品久久久免费视频 | 免费在线观看av的网站 | 亚洲男男gaygay无套同网址 | 国模吧一区 | 激情视频免费观看 | 97精品国产 | 97在线免费视频观看 | 亚洲一区二区视频在线 | 国产视频在 | 日本三级国产 | 天天弄天天干 | 日韩偷拍精品 | 九九爱免费视频在线观看 | 18久久久 | 国产人免费人成免费视频 | 国产精品久久婷婷六月丁香 | 欧美最新另类人妖 | 五月天网页| 亚洲精品乱码白浆高清久久久久久 | 97电影在线观看 | caobi视频| 日本夜夜草视频网站 | 视色网站 | 欧美日韩国产一二三区 | 欧美在线99 | 久草99 | 最近中文字幕mv免费高清在线 | 视频在线99 | 天天操综 | 亚洲少妇天堂 | 国产午夜小视频 | 国产精品久久久久久久妇 | 99色免费| 超碰最新网址 | 欧洲一区二区三区精品 | www.xxxx变态.com| 午夜影院在线观看18 | 欧美精品久久久久久久久免 | 五月婷婷免费 | 8x成人免费视频 | 欧美日韩久久不卡 | 麻豆国产网站 | 中文字幕永久免费 | 久久久久国产精品免费 | 激情久久五月 | 国产乱码精品一区二区三区介绍 | 天天射天天操天天 | 麻豆国产露脸在线观看 | 日韩中文字幕91 | 亚洲最大激情中文字幕 | 亚洲黄色软件 | 美女搞黄国产视频网站 | 欧美激情精品久久久 | 国产一卡久久电影永久 | 精品国产不卡 | 四虎在线视频免费观看 | 99精品视频免费观看 | www.99在线观看| 国产情侣一区 | 正在播放五月婷婷狠狠干 | 91精品视频免费在线观看 | 久久久国产精品久久久 | 99在线国产 | 91看片在线观看 | 九九免费在线观看视频 | 欧美9999 | 日本性xxx| 91视频91色| 中文字幕一区在线观看视频 | 天天操人人干 | 在线午夜电影神马影院 | 国产高清无线码2021 | 久久在现视频 | 在线观看韩国av | 国产成人不卡 | 国产免费叼嘿网站免费 | 在线黄色国产 | 免费在线观看视频a | 精品福利网 | 成人久久18免费网站图片 | 免费欧美高清视频 | 一区二区三区在线免费观看视频 | 欧美色图亚洲图片 | 日韩精品一区二区三区视频播放 | 午夜精品电影一区二区在线 | 久久综合中文字幕 | 在线a亚洲视频播放在线观看 | 在线av资源 | 久久久久这里只有精品 | 高清国产午夜精品久久久久久 | 日韩免费福利 | 亚洲爽爽网 | 久久国产色 | 日本久久视频 | 国产精品免费观看视频 | 亚洲电影成人 | 久久久天堂 | 久久天天综合网 | 在线亚洲成人 | 欧美日韩一区二区在线观看 | 欧美人牲| 91av在| 免费a网址 | 丰满少妇高潮在线观看 | 亚洲黄色免费网站 | 毛片1000部免费看 | 麻豆一区二区三区视频 | 国产这里只有精品 | 久久久久久伊人 | 午夜视频欧美 | 激情婷婷综合 | 精品久久久久久久久久久院品网 | 日日天天 | 中文在线字幕免费观 | 欧美韩日视频 | 久久久不卡影院 | 国产午夜精品一区 | 久久久久成人精品 | 久久久高清免费视频 | 成人在线一区二区 | 天堂麻豆 | 国产精品午夜久久 | 99久久久久久久 | 亚洲精品免费观看 | 成年人视频免费在线播放 | 成人午夜影视 | 日日日日干| 午夜视频一区二区三区 | 日日爽视频| 99久久精品国产免费看不卡 | 99这里只有精品视频 | 久久激情综合网 | 在线看的av网站 | 日日干av| 九七视频在线观看 | 欧洲精品二区 | 日韩成人在线免费观看 | 人人网人人爽 | 久久天天躁夜夜躁狠狠85麻豆 | 久久国产手机看片 | 国产精品白浆视频 | 黄色免费观看 | 国产福利一区二区三区视频 | 91超在线| 久草在线欧美 | 西西4444www大胆无视频 | 天天综合91 | 91视频成人免费 | 国产传媒中文字幕 | 中文在线天堂资源 | 亚洲天堂va| 波多野结衣精品 | 人人爽爽人人 | 日本三级不卡 | 91大神精品视频 | 久久精品成人热国产成 | 成人免费视频a | 91人人澡人人爽人人精品 | 亚洲一片黄| 成人免费在线观看av | 国产精品一区二 | 久久午夜鲁丝片 | 视频在线一区 | 国产精品男女视频 | 久久99在线视频 | 永久黄网站色视频免费观看w | 欧美一级电影免费观看 | 91av资源网| 亚洲专区欧美专区 | 日韩免费中文字幕 | 婷婷激情五月 | 国内99视频| 深爱激情五月网 | 中国老女人日b | 欧美日韩在线视频一区二区 | 久久久久久久久久伊人 | 免费精品久久久 | 国产福利a | av黄色免费看 | 欧美一级艳片视频免费观看 | 欧美精品免费在线观看 | 蜜臀av一区二区 | 色99之美女主播在线视频 | 天堂麻豆 | 中文日韩在线 | 色综合天天干 | 日韩久久一区 | 国产99久久 | 国产成人香蕉 | 久久不射电影院 | 久久免费视频精品 | 国产精品自产拍在线观看蜜 | 日韩丝袜 | 日韩91av| 在线观看v片 | 狠狠的日日| 青草视频网 | 综合婷婷丁香 | 福利一区二区 | 亚洲精品456在线播放乱码 | 国产一区二区三区在线免费观看 | 久久久999 | 最近中文字幕大全中文字幕免费 | 久久天天躁 | 欧美一区二区在线看 | 日韩欧美在线观看一区二区 | 99精品久久久久久久 | 国产成人精品一区在线 | 日韩av区| 成年免费在线视频 | 96亚洲精品久久久蜜桃 | 在线黄色观看 | 欧美久久99 | 婷婷在线看 | av中文字幕日韩 | 色天天综合久久久久综合片 | 久久久九色精品国产一区二区三区 | 日韩在线播放av | 国产又黄又猛又粗 | 黄色福利| 亚洲黄色网络 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 亚洲欧美国产精品 | 欧美亚洲另类在线视频 | 国产成人精品av久久 | 久久电影网站中文字幕 | 欧美日韩在线免费视频 | 91麻豆精品国产91久久久久久 | 激情五月色播五月 | 激情动态| 免费观看版 | 久久免费黄色网址 | 亚洲国产丝袜在线观看 | 国产91精品一区二区麻豆亚洲 | 又色又爽又黄高潮的免费视频 | www99精品| 亚洲 综合 国产 精品 | 国产四虎在线 | 99精品在线| 欧美精品二区 | 国产精品色婷婷视频 | 国产在线观看黄 | 中文字幕一区2区3区 | 91看片淫黄大片在线播放 | 欧美精品一级视频 | 不卡在线一区 | 色www.| 99中文字幕视频 | 久久色视频| 精品久久一二三区 | 亚洲精品www. | 在线免费黄色av | 草免费视频 | 国产免费片 | 国产色啪| 久久亚洲人 | 国产又粗又猛又色又黄视频 | www·22com天天操| 黄色成人在线网站 | 在线视频日韩一区 | 91精品1区2区 | 中文字幕在线免费看 | 91精品一区二区三区蜜桃 | 9999亚洲| 成人在线视频论坛 | 欧美综合久久 | 国产色婷婷在线 | 久久综合色一综合色88 | 97在线观看免费观看 | jizzjizzjizz亚洲| 久久96 | 国产精品成人a免费观看 | 日本三级久久 | 激情图片久久 | 蜜臀91丨九色丨蝌蚪老版 | 97操碰| 欧美精品在线观看一区 | 在线视频观看国产 | 日韩一区二区三区免费视频 | 玖玖在线播放 | 欧美成人在线免费观看 | 成人在线播放免费观看 | 中文字幕91| 日日夜夜精品 | 精品久久久久久国产 | 2023av在线| 久久免费视频这里只有精品 | 91精品在线播放 | 欧美日韩精品免费观看视频 | 亚洲有 在线 | 欧美精品久久久 | 久久99久久99久久 | 天天摸天天操天天舔 | 亚洲a在线观看 | 亚洲精品小视频在线观看 | 五月天狠狠操 | 国产一区二区三区免费在线观看 | 狠狠操夜夜 | 一区二区视频在线观看免费 | 日韩免费观看av | www国产精品com | 中文理论片 | www.色爱| www.久久久.cum | jizz18欧美18 | 在线影院 国内精品 | va视频在线 | 69av免费视频 | 91福利国产在线观看 | 中文字幕在线观看的网站 | 韩国av一区二区三区在线观看 | 97超视频免费观看 | 91最新在线观看 | 美女福利视频 | 久久乐九色婷婷综合色狠狠182 | 波多野结衣资源 | 欧美aa级 | 四虎免费在线观看视频 | 久久久人 | a成人在线| 精品欧美一区二区在线观看 | 久久久久久久久久久久亚洲 | 天天爱天天插 | 999毛片 | 天天操天天操一操 | 婷婷久久五月天 | 免费av福利 | 激情欧美丁香 | 天天舔天天搞 | 色九九在线| 国产污视频在线观看 | 人人爱爱 | 久久精品a | av不卡免费看 | www狠狠| 综合av在线| 国产69精品久久久久9999apgf | 狠狠婷婷 | 久久精品这里精品 | 久久人人爽爽 | 日韩黄色一区 | 国产999视频在线观看 | 国产一区自拍视频 | 日韩午夜高清 | 日韩美女一级片 | 欧美一二区视频 | 韩日av在线 | 天天草综合 | 五月婷婷丁香六月 | 在线观看视频你懂 | 国产精品免费久久久久 | 久久欧洲视频 | 免费观看91视频 | 成人av一二三区 | 国产精品女 | www黄色软件 | 久久伊人精品一区二区三区 | 久久伊人精品一区二区三区 | 婷婷综合五月 | 国产精品第十页 | 激情网站网址 | 亚洲成人动漫在线观看 | 国产精品免费在线观看视频 | 中文字幕丝袜美腿 | 久久久午夜精品理论片中文字幕 | 国产小视频在线观看 | 久久久国产精品网站 | 欧美日韩另类视频 | 成人免费 在线播放 | 91看片麻豆 | 青青草在久久免费久久免费 | 国产尤物视频在线 | 中文字幕日本电影 | 国产伦理久久精品久久久久_ | 日韩在线观看三区 | 中文字幕资源在线 | 尤物一区二区三区 | 国产伦精品一区二区三区照片91 | 国产三级午夜理伦三级 | 久久精品久久久久久久 | aa一级片| 1000部18岁以下禁看视频 | www.久久色.com| 麻豆视频免费 | 久久er99热精品一区二区三区 | 国产日韩精品在线观看 | 天天夜夜操 | 欧美日韩中文字幕在线视频 | 91精品免费在线视频 | 色综合咪咪久久网 | 9999激情 | 天天射日 | 中文字幕亚洲在线观看 | 免费日韩一级片 | 日日操天天操夜夜操 | 国产欧美在线一区二区三区 | 午夜视频二区 | 国产一区二区在线视频观看 | 福利视频第一页 | 国产福利91精品一区二区三区 | 国产免码va在线观看免费 | 成年人精品 | 国产国语在线 | 国产又粗又猛又爽又黄的视频先 | 日韩精品网址 | 亚洲精品99久久久久中文字幕 | 伊人va| 99re国产 | 日本午夜免费福利视频 | 免费看的黄色 | 久久久久久伊人 | 久久精品国产亚洲精品2020 | 精品一区二区在线免费观看 | 亚洲精品美女久久17c | 国产日产精品久久久久快鸭 | 天天干天天操人体 | 欧美日韩免费看 | 日韩精品视频在线观看网址 | 日韩在线视频不卡 | 成人黄色在线视频 | 国产欧美精品一区二区三区四区 | 久久久999免费视频 日韩网站在线 | 欧美性大战 | 国产精品理论在线观看 | 亚洲国产精品va在线看 | 三级黄色网址 | 91在线视频免费观看 | 免费在线观看av的网站 | 999久久国精品免费观看网站 | 久草在线网址 | 精品1区二区 | 狠狠色丁香久久婷婷综合丁香 | 免费日韩 精品中文字幕视频在线 | 国产日韩欧美在线影视 | 国产91aaa| 久久成视频 | 久草在线观看视频免费 | 国产精品免费久久久久久久久久中文 | 亚洲经典在线 | 五月激情站 | 亚洲乱码在线 | 国产韩国精品一区二区三区 | 天天操夜夜干 | 中文字幕日韩国产 | 东方av在| 国产首页 | 精品福利在线视频 | 99热国产在线观看 | 9幺看片 | 日韩在线欧美在线 | 欧美另类色图 | 日韩伦理一区二区三区av在线 | 亚洲经典视频在线观看 | 毛片网站观看 | 黄色1级大片 | 色无五月 | 中文成人字幕 | 亚洲精品综合欧美二区变态 | 综合激情av | 亚洲网站在线看 | 91亚洲精品国偷拍 | 国产一区二区三区网站 | 91av小视频 | 色婷婷免费视频 | 国产色网 | 亚洲视屏在线播放 | 五月婷婷狠狠 | 久久国语 | 西西444www大胆高清视频 | 不卡电影免费在线播放一区 | 久久久久久国产精品久久 | 国产视频手机在线 | 波多野结衣在线视频一区 | 天天干天天玩天天操 | 在线小视频 | 在线观看视频 | 美女精品在线观看 | 国产又粗又猛又色又黄网站 | av在线播放亚洲 | 亚洲综合导航 | 国产精品自在欧美一区 | 久久精品超碰 | 精品国产午夜 | av视屏在线播放 | 中文资源在线官网 | 日韩伦理一区二区三区av在线 | 国产尤物一区二区三区 | 一级黄色大片 | 亚洲精品一区二区久 | 亚洲码国产日韩欧美高潮在线播放 | 国产成人福利在线观看 | 99热国产精品 | 五月激情久久久 | 日黄网站 | 精品伊人久久久 | 久久精品久久精品 | 免费无遮挡动漫网站 | 久久最新视频 | 日日干激情五月 | 美女一二三区 | 一区二区免费不卡在线 | 色九九影院 | 免费观看特级毛片 | 国产麻豆精品久久一二三 | 九九九九九九精品任你躁 | 91.麻豆视频 | 亚洲成人av影片 | 九九综合在线 | 成 人 黄 色 视频 免费观看 | 日韩一二区在线观看 | 免费在线观看日韩欧美 | 国产精品福利在线播放 | 日韩av免费观看网站 | 一色屋精品视频在线观看 | 夜夜澡人模人人添人人看 | 国产精品6 | 久久人91精品久久久久久不卡 | 免费在线观看91 | 8x成人在线 | 亚洲精品乱码久久久久久蜜桃91 | 人人爽夜夜爽 | 天天操天天色天天 | 97人人人人 | 97国产在线视频 | 456免费视频 | 亚洲天堂自拍视频 | 久久久久一区 | 九色91在线| 久久观看免费视频 | 狠狠操综合网 | 91麻豆产精品久久久久久 | 综合在线亚洲 | 天天摸天天操天天舔 | 欧美国产视频在线 | 欧美日韩视频在线观看一区二区 | 激情视频国产 | 国产黄色片久久久 | 91看片在线观看 | 99爱精品视频 | 日韩色av色资源 | 制服丝袜亚洲 | 狠狠躁夜夜av| 美女精品久久久 | 国产一级二级在线 | 91麻豆免费视频 | 成人午夜片av在线看 | av中文天堂在线 | 久久9999久久免费精品国产 | 久久精品一区二区三区国产主播 | 欧美精品久久久久久久久久丰满 | 久久成人国产精品入口 | 在线综合 亚洲 欧美在线视频 | 婷婷亚洲最大 | av中文国产| 亚洲不卡av一区二区三区 | 久久精品国产美女 | 成全免费观看视频 | 五月婷婷在线视频观看 | 伊人手机在线 | 欧美日韩中文字幕在线视频 | 色综合久久综合 | av在线免费观看网站 | 国模视频一区二区三区 | 日本精品一区二区三区在线观看 | 日韩视频区 | 成人在线免费观看视视频 | 国产午夜在线 | 久久人人爽视频 | 激情视频免费观看 | 久草免费在线视频观看 | 婷婷成人亚洲综合国产xv88 | 九九导航| 精品在线视频观看 | 免费视频久久久 | 色婷婷久久 | 中文字幕在线观看不卡 | 欧美激情精品久久久久久免费印度 | 中文高清av | 少妇18xxxx性xxxx片| 免费观看一级成人毛片 | 91福利视频免费观看 | 亚洲波多野结衣 | 九九九在线 | 天天色综合1 | 久久国产精品免费一区二区三区 | 久久国产精品网站 | 激情图片qvod| 国产美女视频 | 色婷婷电影网 | 91麻豆精品久久久久久 | 99综合视频 | 亚州av成人| 69夜色精品国产69乱 | 天堂av在线 | 久久在线一区 | 久久久久美女 | 国产视频久久久 | 亚洲国产999 | 97福利| 国产精品日韩精品 | 一级黄色片在线观看 | 在线观看国产一区 | 中文字幕一区二区三区在线视频 | 91精品国产综合久久久久久久 | 久草香蕉在线 | 美女av免费看 | 97超碰人人 | 中文字幕在线播放av | 亚洲成人免费在线 | 国产精品免费久久久久久久久久中文 | 青草草在线| 香蕉视频在线视频 | 国产不卡在线观看 | 久久久午夜视频 | 91久久偷偷做嫩草影院 | 在线观看黄a | 成人av影视在线 | 黄免费网站 | 香蕉久草 | 香蕉视频国产在线 | 国产一级二级av | 欧美 日韩 国产 中文字幕 | 色播六月天 | 欧美午夜理伦三级在线观看 | 欧美有色| 国产精品99久久久久久久久 | 丁香六月天 | 高清av免费看 | 中文字幕一区二区三区乱码不卡 | 国产精品福利小视频 | 91免费国产在线观看 | 九九九在线观看 | 国产精品手机在线 | 精品国产乱码一区二区三区在线 | 久久国产精品一国产精品 | 欧美黄网站 | 日本在线观看一区 | 一区二区精品 | 激情av综合| 久久新 | 西西4444www大胆视频 | 亚洲国产精品久久久久婷婷884 | 九九九在线观看 | 麻豆91网站 | 成人亚洲欧美 | 亚洲精选在线观看 | 久久草网| 808电影| 中文字幕第一页在线 | 久久久久黄 | 日韩av视屏在线观看 | 四虎永久国产精品 | 国产精品麻豆99久久久久久 | 国模精品一区二区三区 | 狠狠躁日日躁狂躁夜夜躁av | 久久99国产精品免费网站 | 久久久久久久久久影视 | 精品国产一二三四区 | 在线国产视频一区 | 亚洲va综合va国产va中文 | 51久久夜色精品国产麻豆 | 中文字幕一区二区三区四区在线视频 | 久久久国产在线视频 | 国产精品久久久久av福利动漫 | 最近中文字幕高清字幕在线视频 | 99精品国产一区二区三区麻豆 | 亚洲91在线 | 丝袜美腿一区 | 丁香5月婷婷久久 | 99综合久久| 91精品国产欧美一区二区成人 | 久久婷五月 | 激情五月综合网 | 国产精品大全 | 亚洲视频在线播放 | 国产精品国内免费一区二区三区 | 黄色精品久久久 | 午夜在线免费观看视频 | 亚洲精欧美一区二区精品 | 久久久久久免费视频 | 黄色三级免费看 | 成人超碰97 | 婷婷丁香久久五月婷婷 | 91理论片午午伦夜理片久久 | 免费人人干| 久久99久久99免费视频 | 天天干天天干天天射 | 日韩av片无码一区二区不卡电影 | 日日夜夜人人天天 | 久久久久久久免费 | www.天天操 | 成年人免费看片 | 精品国产一区二区三区蜜臀 | 亚洲1区在线 | 国产精品一区二区免费看 | 中文国产字幕在线观看 | 日韩亚洲国产中文字幕 | 亚洲精品男人的天堂 | 国产精品精品久久久久久 | 深爱婷婷网 | 久久久精品国产一区二区电影四季 | a级国产乱理论片在线观看 伊人宗合网 | 91av电影网 | 亚洲精品在线观看视频 | 国产精品欧美日韩在线观看 | 91丨九色丨国产在线观看 | 欧美精品v国产精品v日韩精品 | 午夜久操| 综合久久久久久 | 日韩免费三区 | 国产精品乱码高清在线看 | 色在线免费观看 | 精品一二三四在线 | 九九99| av免费观看高清 | 婷婷亚洲五月色综合 | 久久精品一区二区三区视频 | 人人爽人人爽人人爽学生一级 | 成人亚洲综合 | av一区二区三区在线 | av大全在线免费观看 | 91黄色免费看 | 91丨九色丨国产在线观看 | 久久视频免费观看 | 麻豆成人在线观看 | 亚洲国产午夜精品 | 久久影院中文字幕 | 免费看的黄色的网站 | 婷婷色在线资源 | 国产拍在线 | 亚洲男男gaygay无套同网址 | 激情视频综合网 | 亚洲国产电影在线观看 | 国内精品在线观看视频 | 天天色天天骑天天射 | 99re6热在线精品视频 | 欧美日韩激情视频8区 | 欧美国产精品一区二区 | 色99之美女主播在线视频 | 91视频-88av | 久久丁香 | 中文字幕 二区 | 亚洲美女精品视频 | 国产在线日本 | 中文字幕中文字幕在线中文字幕三区 | 精品久久久久久久久久久久久 | 九草视频在线 | 91超级碰碰 | 国产精品手机在线播放 | 超碰日韩| 日韩中文字幕在线 | 热re99久久精品国产99热 | 婷婷丁香激情 | 日韩免费电影一区二区 | 久草观看视频 | 日韩aⅴ视频 | 日韩免费专区 | 国产精品白虎 | 毛片a级片 | 国产精品久久久久久久久久久久午夜片 | 精品亚洲一区二区三区 | 亚洲精品自拍 | 五月天婷婷免费视频 | 午夜视频不卡 | 97超碰成人在线 | 91免费视频网站在线观看 | 国产精品欧美久久久久三级 | 在线观看视频一区二区三区 | 99精品欧美一区二区三区 | 亚洲一级影院 | 91视频最新网址 | 在线va视频 | 精品一区精品二区 | 五月开心婷婷网 | 国产精品一区二区av麻豆 | 欧美日韩精品国产 | 美女免费黄网站 | 国产精品成人在线观看 | 91看毛片 | 黄色大片日本免费大片 | 在线观看日本韩国电影 | 97色国产 | 日韩欧美电影在线 | av怡红院| 999成人| 狠狠色丁香久久婷婷综合_中 | 高清av在线免费观看 | 久久久久福利视频 | av免费看在线 | 欧美一区二区视频97 | 美女免费网视频 | 视频在线观看入口黄最新永久免费国产 | 天天综合网天天综合色 | 超碰人人舔 | 天天干天天操天天射 | 婷婷5月色 | 最近中文字幕完整视频高清1 | 麻豆精品91 | 91精品办公室少妇高潮对白 | 人人插人人澡 | 国产成人精品不卡 | 日本一区二区免费在线观看 | 天天操天操 | 天天在线视频色 | 中文字幕888 | 69国产在线观看 | 激情自拍av | 亚洲午夜精品久久久久久久久 | 午夜 在线 | 欧美性精品 | 日韩精品在线免费播放 | 久久美女高清视频 | 久久艹在线| 免费成人结看片 | 狠狠的操你| 97视频精品 | 日韩精品免费一区二区 | 国产精品久久久久久一区二区 | 日韩av区| 国产精品观看在线亚洲人成网 | 国产精品不卡 | 狠狠操夜夜 | 国产视频日韩视频欧美视频 | 久久免费公开视频 | 六月婷操 | 午夜视频在线观看欧美 | 免费网站污 | 国产一区在线免费观看 | 视频在线日韩 | 日韩欧美在线第一页 | 国产精品欧美日韩 | 麻豆果冻剧传媒在线播放 | 麻豆国产精品va在线观看不卡 | 狠狠撸电影 | 中文字幕在线观看视频一区二区三区 | 又黄又爽又色无遮挡免费 | 国产剧在线观看片 | 免费观看午夜视频 | 九九热在线播放 | 午夜视频色 | 欧美一级片免费 | 国产精品成人久久 | 久久久久www | 中文字幕在线观看视频一区二区三区 | 视频在线观看国产 | 国产系列精品av | 亚洲在线视频免费 | 亚洲a资源 | 欧美精品久久久久久久久久丰满 | 国产日女人 | 超碰人人超碰 | 亚洲欧洲精品视频 | 国产精品自产拍在线观看网站 | 精品国产伦一区二区三区免费 | 欧美精品乱码99久久影院 | 美女国产 | 99九九99九九九视频精品 | 蜜臀久久99精品久久久久久网站 | 日韩黄色免费电影 | 久久久久五月 | 成人高清在线 | 久久无码精品一区二区三区 | 夜夜操网站 | av 一区二区三区四区 | 国产女教师精品久久av | 国产高清日韩欧美 | av一区在线播放 | 午夜三级影院 | av中文字幕亚洲 | 四虎在线观看视频 | 国产香蕉在线 | 午夜视频免费播放 | 91看片麻豆 | 久久综合久久伊人 | 亚洲黄色在线 | 久草在线视频国产 | 色片网站在线观看 | 久久久精品一区二区 | 国产无吗一区二区三区在线欢 | 国产综合在线观看视频 | 日韩素人在线观看 | 亚洲免费国产视频 | 97超级碰碰 | 精品国产美女在线 | 久久五月激情 | 不卡av在线免费观看 | 91成人在线观看喷潮 | 久久成人一区二区 | 国产系列精品av | 六月丁香婷婷久久 | 在线亚洲成人 | 国产色就色 | 欧美日bb | 国产精品久久99综合免费观看尤物 | 韩国视频一区二区三区 | 成在人线av | 中文字幕中文字幕中文字幕 | 成人午夜网址 | 久久成人精品视频 | 久久91久久久久麻豆精品 | av电影 一区二区 | 91麻豆精品国产91久久久久久 | 九九热在线视频免费观看 | 97中文字幕| 国产视频一二三 | 国产精品久久久久久久久久久久冷 | 国产精品自产拍在线观看桃花 | 日韩精品中文字幕一区二区 | 国产精品99久久久久久小说 | 日韩av区| 在线观看黄网 | 美女视频黄,久久 | 在线观看视频黄 | 久久免费一 | 婷婷色狠狠 | 日本xxxx裸体xxxx17 | 国产成人精品一区二三区 | 日本三级中文字幕在线观看 | 欧美成人视 | 色资源二区在线视频 | 久久久免费毛片 | 国产高清在线a视频大全 | 日本三级久久久 |