社区讨论

自己写的快速排序只能拿60分,求助

P1177【模板】排序参与者 3已保存回复 4

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
4 条
当前快照
1 份
快照标识符
@lo2bkgt2
此快照首次捕获于
2023/10/23 11:09
2 年前
此快照最后确认于
2023/11/03 11:19
2 年前
查看原帖
用了随机选择基准,快读 代码如下:
CPP
#include<iostream>
#include<cstdlib>
#include<cctype>
#include<iomanip>
using namespace std;
const int N = 1e5 + 5;
int n, list[N];
int read() {
    int s = 0; char ch = getchar();
    while (!isdigit(ch))ch = getchar();
    while (isdigit(ch)) {
        s = (s << 1) + (s << 3) + (ch ^ 48);
        ch = getchar();
    }
    return s;
}
void qs(int x, int y) {
    int l = x, r = y;
    if (l >= r)return;
    int pi = rand() % (y - x + 1) + x;
    int p = list[pi];
    swap(list[pi], list[r]);
    r--;
    while (l < r) {
        while (l < r && list[l] < p)l++;
        while (l < r && list[r] >= p)r--;
        swap(list[l], list[r]);
    }
    if (list[l] > p)swap(list[l], list[y]);
    else l++;
    qs(x, l - 1);
    qs(r + 1, y);
}
int main() {
    n = read();
    for (int i = 0; i < n; i++)list[i] = read();
    qs(0, n - 1);
    for (int i = 0; i < n; i++)cout << list[i] << " ";
}

回复

4 条回复,欢迎继续交流。

正在加载回复...