码迷,mamicode.com
首页 > 其他好文 > 详细

普林斯顿大学算法课 Algorithm Part I Week 3 求第K大数 Selection

时间:2014-10-02 14:06:22      阅读:178      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   使用   ar   strong   sp   

问题

给定N个元素的数组,求第k大的数。

特例
当k=0时,就是求最大值,当k=N-1时,就是求最小值。

应用
顺序统计
求top N排行榜

基本思想

使用快速排序方法中的分区思想,使得a[k]左侧没有更小的数,右侧没有更大的数

性能

快速选择算法的复杂度是N。

最坏情况下的复杂度是1/2N^2,但是可以通过预先洗牌来防止出现最坏情况

 

public static Comparable select(Comparable[] a, int k)
{
    StdRandom.shuffle(a);
    int lo = 0, hi = a.length - 1;
    while ( hi > lo)
    {
        int j = partition(a, lo, hi);
        if      (j < k) lo = j + 1;
        else if (j > k) hi = j - 1;
        else           return a[k];    
    }            
    return a[k];
}               

 

原文地址

普林斯顿大学算法课 Algorithm Part I Week 3 求第K大数 Selection

标签:style   blog   http   color   io   使用   ar   strong   sp   

原文地址:http://www.cnblogs.com/Jimtastic/p/4003937.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!