无奖竞猜
  • 板块灌水区
  • 楼主__Q_w_Q__
  • 当前回复8
  • 已保存回复8
  • 发布时间2024/9/11 21:25
  • 上次更新2024/9/12 12:50:55
查看原帖
无奖竞猜
933380
__Q_w_Q__楼主2024/9/11 21:25

求助

#include <iostream>
#include <cstdlib>
using namespace std;

int n;
int d[10000];

int find(int L, int R, int k) {
    int x = rand() % (R - L + 1) + L;
    swap(d[L], d[x]);
    int a = L + 1, b = R;
    while (a < b) {
        while (a < b && d[a] < d[L])
            ++a;
        while (a < b && d[b] >= d[L])
            --b;
        swap(d[a], d[b]);
    }
    if (d[a] < d[L])
        ++a;
    if (a - L == k)
        return d[L];
    if (a - L < k)
        return find(a, R, k - (a - L));
    return find(L + 1, a - 1, k);
}

int main() {
    int k;
    cin >> n;
    cin >> k;
    for (int i = 0; i < n; ++i)
        cin >> d[i];
    cout << find(0, n - 1, k);
    return 0;
}        

这是 20XX 年 S 组阅读程序 T2

求代码作用及推理过程

2024/9/11 21:25
加载中...