比赛 20120217 评测结果 AAAAAAAAAA
题目名称 编码问题 最终得分 100
用户昵称 王者自由 运行时间 0.000 s
代码语言 C++ 内存使用 0.00 MiB
提交时间 2012-02-17 19:26:25
显示代码纯文本
#include <cstdio>
#include <cstring>
const int N = 110;
int n, m, s, a[N], b[N], x;
bool c[N];
int main() {
    freopen("code.in", "r", stdin);
    freopen("code.out", "w", stdout);
    scanf("%d %d", &m, &n);
    for(int k=0; k<m; k++) {
        scanf("%d", &s);
        memset(a, 0, sizeof(a));
        memset(b, 0, sizeof(b));
        if(s == 1) {
            for(int i=1; i<=n; i++)
                scanf("%d", a+i);
            for(int i=1; i<=n; i++)
                for(int j=1; j<i; j++)
                    if(a[i] > a[j])
                        b[i]++;
            for(int i=1; i<n; i++)
                printf("%d ", b[i]);
            printf("%d\n", b[n]);
        } else if(s == 2) {
            for(int i=1; i<=n; i++)
                scanf("%d", b+i);
            memset(c, true, sizeof(c));
            for(int i=n; i>0; i--) {
                x = 0;
                for(int j=0; j<n; j++) 
                    if(c[j]) {
                        x++;
                        if(x > b[i]) {
                            a[i] = j;
                            c[j] = false;
                            break;
                        }
                    }
            }
            for(int i=1; i<n; i++)
                printf("%d ", a[i]);
            printf("%d\n", a[n]);
        }
    }
    return 0;
}