给定一个长度为m<=1000000的无序正整数序列,以及另一个数n(1<=n<=1000000),接下来以类似快速排序的方法找到序列中第n大的数
关于第n大的数:例如序列{1,2,3,4,5,6}中第3大的数是4。
#include <iostream> #include <stdlib.h> using namespace std; int a[1000001],n,ans = -1; void swap(int &a,int &b) { int c; c = a; a = b; b = c; } int FindKth(int left, int right, int n) { int tmp,value,i,j; if (left == right) return left; tmp = rand()% (right - left) + left; swap(a[tmp],a[left]); value =____(1)______ i = left; j = right; while (i < j) { while (i < j && _____(2)_____) j--; if (i < j) {a[i] = a[j]; i++;} else break; while (i < j && _____(3)_____) i++; if (i < j) {a[j] = a[i]; j--;} else break; } _____(4)_____ if (i < n) return FindKth(______(5)______); if (i > n) return ______(6)________ return i; } int main() { int i; int m; cin>>m; for (i = 1;i <= m;i ++) cin>>a[i]; cin>>n; ans = FindKth(1,m,n); cout<<a[ans]; return 0; }