社区讨论
堆排序和选择排序都挂了,求助
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 条回复,欢迎继续交流。
正在加载回复...