有一個整數陣列,請你根據快速排序的思路,找出陣列中第K大的數。
給定一個整數陣列a,同時給定它的大小n和要找的K(K在1到n之間),請返回第K大的數,保證答案存在。
測試樣例:
[1,3,5,2,2],5,3

http://blog.csdn.net/hymanxq/article/details/51026818

public class 尋找第K大的數 {

    public static void main(String[] args) {
// TODO Auto-generated method stub
int[] a = { , , , , }; System.out.println(findKth(a, a.length, ));
/*
* qsort(a, 0, a.length-1); for(int i:a){ System.out.print(i+" "); }
*/
} public static int findKth(int[] a, int n, int K) {
// write code here return qs(a, , a.length - , a.length - K); // 第K大數 的下標
} static void qsort(int[] a, int left, int right) {
if (left < right) {
int p = partition(a, left, right);
qsort(a, left, p - );
qsort(a, p + , right);
}
} static int qs(int[] a, int left, int right, int k) {
// if (left < right)
{
int p = partition(a, left, right);
if (p == k) {
return a[p];
} else if (p > k)
return qs(a, left, p - , k);
else
return qs(a, p + , right, k);
}
} static int partition(int[] a, int left, int right) {
int p = a[left]; while (left < right) {
while (left < right && a[right] >= p) {
right--;
}
if (left < right) {
a[left++] = a[right];
} while (left < right && a[left] <= p) {
left++;
}
if (left < right) {
a[right--] = a[left];
}
}
a[left] = p;
return left;
}
}