提交记录 20601
提交时间 |
评测时间 |
2023-11-27 21:35:12 |
2023-11-27 21:35:17 |
#include <cstdlib>
#include <cstddef>
#include <algorithm>
using uint = unsigned;
const size_t n = 1e8;
void F(uint* buc, uint* a, uint* b, auto foo) {
uint* ptr[256];
for (size_t i = 0; i < 256; i++) ptr[i] = b + buc[i];
uint64_t index[8];
for (size_t i = 0; i < 8; i++) index[i] = a[i];
for (size_t is = 0; is < n - 8; is += 8) {
#pragma GCC unroll 8
for (size_t i = 0; i < 8; i++) {
*ptr[foo(index[i])]++ = index[i], index[i] = a[is + i + 8];
}
}
for (size_t i = 0; i < 8; i++) *ptr[foo(index[i])]++ = index[i];
}
void sort(uint* a, int __n) {
uint buc[4][256] = {};
uint* b = (uint*)malloc(n * sizeof(uint));
for (size_t i = 0; i < n; i++) {
buc[0][a[i] & 255]++;
buc[1][a[i] >> 8 & 255]++;
buc[2][a[i] >> 16 & 255]++;
buc[3][(a[i] >> 16) >> 8 & 255]++;
}
for (size_t k = 0; k < 4; k++) {
uint offset = 0;
for (size_t i = 0; i < 256; i++)
std::swap(buc[k][i], offset), offset += buc[k][i];
}
F(buc[0], a, b, [](uint v) { return v & 255; });
F(buc[1], b, a, [](uint v) { return v >> 8 & 255; });
F(buc[2], a, b, [](uint v) { return v >> 16 & 255; });
F(buc[3], b, a, [](uint v) { return v >> 24; });
}
Compilation | N/A | N/A | Compile OK | Score: N/A | 显示更多 |
Testcase #1 | 784.083 ms | 762 MB + 980 KB | Accepted | Score: 100 | 显示更多 |
Judge Duck Online | 评测鸭在线
Server Time: 2025-09-12 19:10:44 | Loaded in 0 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠