第k序元素排序python_Python|算法|快速排序|如何在O(n)查找第K大元素

王争老师讲过,学习算法不是死记硬背一些源代码或概念,而是学习算法的实现思路、思维、应用场景,从而达到灵活运用。

比如现在要时间复杂度为 O(n),在一个长度为 n 的数组中查找到第 K 大的元素,你会怎么做呢? 你可能会说这很简单啊,第一次遍历数组找到第 1 大元素,第二次遍历找到第 2 大,...,第 K 次就可以找到第 K 大 但是这样的时间复杂度就不是 O(n),而是 K*O(n),当 K 接近 n 时,时间复杂度就是 O(n^2)。 如果你运用快速排序算法的思想,你就可以在 O(n) 的时间复杂度内找到第 K 大元素。

快速排序算法

快速排序算法和归并排序算法一样,都是利用分治算法。但是它们却有本质的不同,归并排序是自下而上,先求解下面的子问题求,然后再逐层归并,最后全部有序;而快速排序是自上而下,下面的子问题解决后,数据就全部有序。

快速排序的思路是这样的,在数组中随机选取一个数据,例如选取最后一个元素 m 做为分区元素,比 m 小的放 m 的左边,反之放右边,再分别对左右边的分区再分别进行分区,直到分区元素缩小到 1 个,此时数据已经全部有序。

下面是我根据理解编写的快速排序代码(python语言)

#encoding=utf-8

import random

def quick_sort(data_list):

length = len(data_list)

quick_sort_c(data_list,0,length-1)

def quick_sort_c(data_list,begin,end):<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值