社区讨论

堆排序和选择排序都挂了,求助

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

讨论操作

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

当前回复
10 条
当前快照
1 份
快照标识符
@lzi43oql
此快照首次捕获于
2024/08/06 15:41
2 年前
此快照最后确认于
2024/08/06 16:32
2 年前
查看原帖
捞一捞堆排序 不知道为什么挂了
还有选择排序(用分块优化)
CPP
#include <iostream>
#include <cmath>

using namespace std;

void choice_sort(int* pInt, int len) {
    int Min = 0;
    for (int i = 0; i < len; i++) {
        for (int j = i; j < len; j++)
            if (pInt[j] < pInt[Min]) Min = j;
        swap(pInt[i], pInt[Min]);
    }
}

void cut_sort(int* begin, int* end) {
    int len = int(end - begin) + 1;
    int lec = sqrt(len), Min;
    for (int i = 0; i < len; i += lec)
        choice_sort(begin + i, i + lec > len ? len - i + 1 : lec);
    for (int h = 0; h < len; h++) {
        Min = 0;
        for (int i = h; i < len; i += lec) {
            if (begin[i] < begin[Min]) Min = i;
            swap(begin[i], begin[h]);
        }
    }
}

int main() {
    int n;
    int a[int(1e5 + 5)];
    cin >> n;
    for (int i = 1; i <= n; i++) cin >> a[i];
    cut_sort(a + 1, a + n + 1);
    for (int i = 1; i <= n; i++) cout << a[i] << ' ';
    return 0;
}

回复

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

正在加载回复...