数据结构算法--3快速排序

快速排序比冒泡排序,选择排序,插入排序速度都快

快速排序思路:

^取一个元素P,(第一个元素),使元素P归位。

^列表被P分成了两部分,左边都比P小,右边都比P大。

^递归完成排序。

数据结构算法--3快速排序_第1张图片

         过程:

        把5拿出来存到tmp,5的位置是指针left,right指针在8,8>5,right指针-1,9又>5,right再次-1

        right来到2,2<5,所以left指针处(5),成为2,此时right指针成为空元素(原来2的位置),所以left指针+1,left到了元素7,由于7>5,所以7要去列表右侧,所以right指针处(原来2的位置),变为7,依次类推,两指针交替变换

完成第一轮归位后,左侧和右侧再次分别进行归位,递归完成排序

def quick_sort(li,left,right):  # 一开始传进来left=0
    if left
def partition(li,left,right):
    tmp=li[left]            # 把第一个值存起来
    while lefttmp:
            right-=1   # 往左走一步
        li[left]=li[right]   # 右边的值写到左边空位上
        while left

如果是一个原本就逆序的数列要排成顺序数列,每一轮都只确定了基准元素的位置

数据结构算法--3快速排序_第2张图片

 这时最坏情况,时间复杂度退化成了O(n方)

我们可以避免这种最坏情况的发生,随机选择一个元素作为基准元素(不是第一个)

这样快速排序时间复杂度可以看出是O(nlogn)

你可能感兴趣的:(数据结构,排序算法,算法,python,leetcode)