找第k大的数(解法3:快速排序)
摘要:View Code 1 var i,k,n:longint; 2 a:array[1..100000]of longint; 3 4 procedure qsort(l,r:longint); 5 var i,j,m,t:longint; 6 begin 7 if l=r then exit; 8 i:=l; j:=r; m:=a[k]; 9 repeat10 while a[i]<m do inc(i);11 while a[j]>m do dec(j);12 if i<j then13 begin14 t:=a[i]; a...
阅读全文
找第k大的数(方法汇总)
摘要:题目:n个数,确定其中第k个最大值。 数据输入:一行,n、k,空格隔开。 数据输出:一个数,第k大的数。所谓“第(前)k大数问题”指的是在长度为n(n>=k)的乱序数组中S找出从大到小顺序的第(前)k个数的问题。解法1: 我们可以对这个乱序数组按照从大到小先行排序,然后取出前k大,总的时间复杂度为O(n*logn + k)。解法2: 利用选择排序或交互排序,K次选择后即可得到第k大的数。总的时间复杂度为O(n*k)解法3: 利用快速排序的思想,从数组S中随机找出一个元素X,把数组分为两部分Sa和Sb。Sa中的元素大于等于X,Sb中元素小于X。这时有两种情况:1. Sa中元素的个数小于k,
阅读全文