第k小的數
Problem Description
現有一個包含n個整數(1<=n<=10000000)的無序序列(保證序列內元素各不相同),輸入一個整數k(1<=k<=n),請用較快的方式找出該序列的第k小數並輸出。
Input
多組輸入。
首先輸入一個數據組數T(1<=T<=100)
接下來是T組數據。
每組數據有兩行。
第一行先輸入兩個整數,n和k。
接下來是一行輸入n個由空格分開的互不相同的整數num(1<=num<=90000000)。
Output
對於每組數據,輸出該組數據中第k小的數num。
Sample Input
1 6 4 3 2 5 1 4 6
Sample Output
4
Hint
Source
#define N 20
int par(int a[], int l, int h)
{
int x = a[l];
while(l < h)
{
while(l < h && a[h] >= x) h--;
a[l] = a[h];
while(l < h && a[l] <= x) l++;
a[h] = a[l];
}
a[l] = x;
return l;
}
int find(int a[], int l, int r, int k)
{
int i;
if(l <= r)
{
i = par(a, l, r);
if(i == k) return a[i];
if(i > k) return (find(a, l, i - 1, k));
else return (find(a, i + 1, r, k));
}
}
int main()
{
int i, n, m, k, t, a[10001];
scanf("%d", &t);
while(t--)
{
scanf("%d", &n);
scanf("%d", &k);
for(i = 1; i <= n; i++)
scanf("%d", &a[i]);
m = find(a, 1, n, k);
printf("%d\n", k);
}
return 0;
}
第k小的數
Problem Description
現有一個包含n個整數(1<=n<=10000000)的無序序列(保證序列內元素各不相同),輸入一個整數k(1<=k<=n),請用較快的方式找出該序列的第k小數並輸出。
Input
多組輸入。
首先輸入一個數據組數T(1<=T<=100)
接下來是T組數據。
每組數據有兩行。
第一行先輸入兩個整數,n和k。
接下來是一行輸入n個由空格分開的互不相同的整數num(1<=num<=90000000)。
Output
對於每組數據,輸出該組數據中第k小的數num。
Sample Input
1 6 4 3 2 5 1 4 6
Sample Output
4