寻找最小的k个数
题目描述:5.查找最小的k个元素
题目:输入n个整数,输出其中最小的k个。
题目描述:5.查找最小的k个元素
题目:输入n个整数,输出其中最小的k个。
例如输入1,2,3,4,5,6,7和8这8个数字,则最小的4个数字为1,2,3和4.
原文:http://blog.csdn.net/v_july_v/article/details/6370650
总结思路:
(1)排序后,输出前面最k个,时间复杂度跟时间复杂度有关,如果是快速排序O(nlogn + k)
(2)只排序前面的k个元素,如果选择排序,时间复杂度O(k*n)
(3)只排序前面的k个元素,如果堆排序是(维护k个节点的最大堆),时间复杂度O(n*logk)
(4)按编程之美第141页上解法二的所述,类似快速排序的划分方法,N个数存储在数组S中,再从数组中随机选取一个数X(随机选取枢纽元,可做到线性期望时间O(N)的复杂度,在第二节论述),把数组划分为Sa和Sb俩部分,Sa<=X<=Sb,如果要查找的k个元素小于Sa的元素个数,则返回Sa中较小的k个元素,否则返回Sa中所有元素+Sb中小的k-|Sa|个元素。像上述过程一样,这个运用类似快速排序的partition的快速选择SELECT算法寻找最小的k个元素,在最坏情况下亦能做到O(N)的复杂度。