提交记录 12108


用户 题目 状态 得分 用时 内存 语言 代码长度
user1 1001. 测测你的排序 Accepted 100 2.486 s 781260 KB C++11 812 B
提交时间 评测时间
2020-03-15 00:51:25 2020-08-01 02:51:26
#include <algorithm>
#pragma GCC optimize ("O3")
void sort(unsigned* a, int n) {
unsigned x[n];
    unsigned i=0, j=n, k;
    while (i<j) {
        if (a[i]<0x80000000U) {unsigned t = a[i++];
            x[t>>5] |= 1 << (t&31);
        } else {
            std::swap(a[i], a[--j]);
        }
    }
    for (j=0, k=0; k<1<<26; ++k) {
        unsigned c=x[k];
        while (c) {
            unsigned q=__builtin_ctz(c);
            a[j++] = k<<5 | q;
            c &= c-1;
        }
        x[k] = 0;
    }
    for (j=i; j<n; ++j) {
        unsigned t = a[j];
        x[(t>>5)-(1<<26)] |= 1 << (t&31);
    }
    for (j=i, k=0; k<1<<26; ++k) {
        unsigned c=x[k];
        while (c) {
            unsigned q=__builtin_ctz(c);
            a[j++] = k<<5 | q | 0x80000000U;
            c &= c-1;
        }
    }
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #12.486 s762 MB + 972 KBAcceptedScore: 100


Judge Duck Online | 评测鸭在线
Server Time: 2026-03-26 15:06:25 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠