提交记录 10547
用户 |
题目 |
状态 |
得分 |
用时 |
内存 |
语言 |
代码长度 |
wys |
1001. 测测你的排序 |
Accepted |
100 |
800.165 ms |
781276 KB |
C++11 |
836 B |
提交时间 |
评测时间 |
2019-09-18 22:32:46 |
2020-08-01 02:16:54 |
#include <string.h>
void sort(unsigned *a, int n){
unsigned *b = new unsigned[n];
unsigned cnt1[256], cnt2[256], cnt3[256], cnt4[256];
memset(cnt1, 0, sizeof(cnt1));
memset(cnt2, 0, sizeof(cnt2));
memset(cnt3, 0, sizeof(cnt3));
memset(cnt4, 0, sizeof(cnt4));
for (int i = 0; i < n; i++) {
cnt1[a[i] & 255]++;
cnt2[(a[i] >> 8) & 255]++;
cnt3[(a[i] >> 16) & 255]++;
cnt4[a[i] >> 24]++;
}
for (int i = 1; i < 256; i++) {
cnt1[i] += cnt1[i - 1];
cnt2[i] += cnt2[i - 1];
cnt3[i] += cnt3[i - 1];
cnt4[i] += cnt4[i - 1];
}
for (int i = n - 1; i >= 0; i--) b[--cnt1[a[i] & 255]] = a[i];
for (int i = n - 1; i >= 0; i--) a[--cnt2[(b[i] >> 8) & 255]] = b[i];
for (int i = n - 1; i >= 0; i--) b[--cnt3[(a[i] >> 16) & 255]] = a[i];
for (int i = n - 1; i >= 0; i--) a[--cnt4[b[i] >> 24]] = b[i];
delete []b;
}
Compilation | N/A | N/A | Compile OK | Score: N/A | 显示更多 |
Testcase #1 | 800.165 ms | 762 MB + 988 KB | Accepted | Score: 100 | 显示更多 |
Judge Duck Online | 评测鸭在线
Server Time: 2024-11-23 23:41:48 | Loaded in 0 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠