提交记录 27840


用户 题目 状态 得分 用时 内存 语言 代码长度
Izumi_Sagiri wc2017b1. 【WC2017】挑战-任务1 Accepted 100 2.251 s 1562524 KB C++17 963 B
提交时间 评测时间
2025-01-27 17:02:50 2025-01-27 17:02:55
typedef unsigned u32;
u32 cnt1[1 << 8], cnt2[1 << 8], cnt3[1 << 8], cnt4[1 << 8];
void sort(unsigned *a, int n)
{
	u32 *tmp = new u32[n];
	u32 *end= a + n;

	#pragma unroll(8)
    for (register u32 *i = a; i != a + n; i++)
		++cnt1[*i & 0xff],
		++cnt2[(*i >> 8) & 0xff],
		++cnt3[(*i >> 16) & 0xff],
		++cnt4[*i >> 24];
		
	#pragma unroll(8)
	for(register u32 *i = cnt1 + 1, *j = cnt2 + 1, *k = cnt3 + 1, *l = cnt4 + 1; i <= cnt1 + 0xff; ++i, ++j, ++k, ++l)
		*i += *(i - 1),
		*j += *(j - 1),
		*k += *(k - 1),
		*l += *(l - 1);

	#pragma unroll(8)
	for(register u32 *i= end - 1; i != a - 1; --i)
		tmp[--cnt1[*i & 0xff]] = *i;
	#pragma unroll(8)
	for(register u32 *i= tmp + n - 1; i != tmp - 1; --i)
		a[--cnt2[(*i >> 8) & 0xff]] = *i;
	#pragma unroll(8)
	for(register u32 *i= end - 1; i != a - 1; --i)
		tmp[--cnt3[(*i >> 16) & 0xff]] = *i;
	#pragma unroll(8)
	for(register u32 *i= tmp + n - 1; i != tmp - 1; --i)
		a[--cnt4[*i >> 24]] = *i;
	delete[] tmp;
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #11.028 ms804 KBAcceptedScore: 34

Testcase #21.125 s762 MB + 988 KBAcceptedScore: 33

Testcase #32.251 s1525 MB + 924 KBAcceptedScore: 33


Judge Duck Online | 评测鸭在线
Server Time: 2025-10-24 20:07:00 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠