結果

問題 No.447 ゆきこーだーの雨と雪 (2)
ユーザー 👑 はまやんはまやんはまやんはまやん
提出日時 2017-04-20 12:33:33
言語 C++14
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 14 ms / 2,000 ms
コード長 1,668 bytes
コンパイル時間 1,983 ms
コンパイル使用メモリ 181,408 KB
実行使用メモリ 13,500 KB
最終ジャッジ日時 2023-09-27 03:15:54
合計ジャッジ時間 4,047 ms
ジャッジサーバーID
(参考情報)
judge14 / judge13
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 5 ms
12,784 KB
testcase_01 AC 5 ms
12,696 KB
testcase_02 AC 5 ms
12,944 KB
testcase_03 AC 6 ms
12,796 KB
testcase_04 AC 6 ms
12,760 KB
testcase_05 AC 9 ms
13,412 KB
testcase_06 AC 12 ms
13,372 KB
testcase_07 AC 9 ms
12,920 KB
testcase_08 AC 9 ms
13,088 KB
testcase_09 AC 11 ms
13,420 KB
testcase_10 AC 6 ms
12,752 KB
testcase_11 AC 7 ms
12,748 KB
testcase_12 AC 7 ms
13,020 KB
testcase_13 AC 11 ms
13,312 KB
testcase_14 AC 12 ms
13,500 KB
testcase_15 AC 6 ms
12,828 KB
testcase_16 AC 6 ms
12,904 KB
testcase_17 AC 6 ms
12,848 KB
testcase_18 AC 6 ms
12,716 KB
testcase_19 AC 14 ms
13,500 KB
testcase_20 AC 13 ms
13,456 KB
testcase_21 AC 6 ms
12,908 KB
testcase_22 AC 6 ms
12,784 KB
testcase_23 AC 7 ms
12,872 KB
testcase_24 AC 12 ms
13,152 KB
testcase_25 AC 14 ms
13,264 KB
testcase_26 AC 8 ms
12,900 KB
testcase_27 AC 8 ms
12,980 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<bits/stdc++.h>
using namespace std;
#define rep(i,a,b) for(int i=a;i<b;i++)




int N, L[30], T;
int M; string Dic[101010];
int ID[101010], Pro[101010];
//-----------------------------------------------------------------------------------
string Name[101010]; char P[101010];
void init() {
    cin.tie(0);
    ios::sync_with_stdio(false);

    cin >> N;
    rep(i, 0, N) cin >> L[i];
    cin >> T;
    rep(i, 0, T) cin >> Name[i] >> P[i];

    map<string, int> za;
    rep(i, 0, T) za[Name[i]] = 0;
    M = za.size();
    int idx = 0;
    for (auto& p : za) za[p.first] = idx, idx++;
    for (auto& p : za) Dic[p.second] = p.first;

    rep(i, 0, T) ID[i] = za[Name[i]], Pro[i] = P[i] - 'A';
}
//-----------------------------------------------------------------------------------
int cnt[30];
int E[101010][30];
int lastsub[101010];
int main() {
    init();

    rep(t, 0, T) {
        int id = ID[t];
        int pid = Pro[t];

        int rank = cnt[pid] + 1;
        cnt[pid]++;

        E[id][pid] = 50 * L[pid] + 500 * L[pid] / (8 + 2 * rank);
        lastsub[id] = t;
    }

    vector<pair<int, int>> v;
    rep(i, 0, M) {
        int sm = 0;
        rep(j, 0, N) sm += E[i][j];
        v.push_back({ sm, lastsub[i] });
    }

    sort(v.begin(), v.end(), [&](pair<int, int> a, pair<int, int> b) {
        if (a.first != b.first) return a.first > b.first;
        else return a.second < b.second;
    });

    rep(i, 0, M) {
        int rank = i + 1;
        int id = ID[v[i].second];
        string name = Dic[id];

        printf("%d %s ", rank, name.c_str());
        rep(j, 0, N) printf("%d ", E[id][j]);
        printf("%d\n", v[i].first);
    }
}
0