1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
| #include <stdio.h> #include <iostream> #include <algorithm> using namespace std;
const int MAXN = 5000001; int vec[MAXN];
int partition(int a[], int i, int j) { int pivot = a[i]; while (i < j) { while (i < j && a[j] <= pivot) j--; if (i < j) a[i++] = a[j]; while (i < j && a[i] >= pivot) i++; if (i < j) a[j--] = a[i]; } a[i] = pivot; return i; }
void quick_sort(int a[], int l, int r) { int pivot_pos; if (l < r) { pivot_pos = partition(a, l, r); quick_sort(a, l, pivot_pos - 1); quick_sort(a, pivot_pos + 1, r); } }
int main(int argc, const char **argv) { int n, k; scanf("%d%d", &n, &k); if (n == 0) { printf("%d", 0); return 0; }
for (int i = 0; i < n; i++) scanf("%d", &vec[i]);
int l = 0, r = n - 1; int pivot_pos = 0; while (true) { pivot_pos = partition(vec, l, r); if (pivot_pos == k - 1) break; else if (pivot_pos > k - 1) r = pivot_pos - 1; else l = pivot_pos + 1; } printf("%d", vec[pivot_pos]);
return 0; }
|