通过划分的方式在线性时间内找出一个序列中第K大的元素

这种划分在快速排序中也用到了:

#py2.7
#coding:utf-8
import random

def findkth(ll, k):
    if k > len(ll):
        raise Exception('Argument error')
    else:
        pivot = ll[random.randrange(0,len(ll))]
        last = 0
        for i in range(1, len(ll)):
            if ll[i] >= pivot:
                last += 1
                swap(ll, i, last)
        swap(ll, 0, last)
        print(ll,k)
        order = last+1
        if order == k:
            return pivot
        elif order < k:
            return findkth(ll[last + 1:], k - order)
        else:
            return findkth(ll[0:last], k)


def swap(ll, i, last):
    tmp = ll[i]
    ll[i] = ll[last]
    ll[last] = tmp


ll = [1, 22, 31, 14, 0.5, 26, 17, 38, 19, 310]
k = 3
print(findkth(ll, k))


转载于:https://www.cnblogs.com/rav009/p/5131100.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值