QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#590493#8230. Submissionsucup-team3519RE 0ms0kbC++204.5kb2024-09-26 01:01:552024-09-26 01:01:55

Judging History

你现在查看的是最新测评结果

  • [2024-09-26 01:01:55]
  • 评测
  • 测评结果:RE
  • 用时:0ms
  • 内存:0kb
  • [2024-09-26 01:01:55]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
#define V vector
#define all0(x) (x).begin(),(x).end()
#define all1(x) (x).begin()+1,(x).end()
#define pb push_back
#define fi first
#define se second
#define lb lower_bound
#define ub upper_bound
#define cin std::cin
#define cout std::cout
typedef long long LL;
typedef pair<int, int> pi;
typedef pair<LL, LL> pl;

//const int MN = 2e5 + 20;
const int INF = 2e9 + 1000;
const LL INFLL = 8e18 + 1000;
mt19937 mrand(chrono::steady_clock().now().time_since_epoch().count());
//模板区域~~~~~~~

//模板结束~~~~~~~

struct val {
    int num, time;
};
bool operator<(val a, val b) {
    if(a.num != b.num) return a.num > b.num;
    return a.time < b.time;
}
val operator+(val a, val b) {
    return {a.num + b.num, a.time + b.time};
}
val operator-(val a, val b) {
    return {a.num - b.num, a.time - b.time};
}


void solve() {
    int m; cin >> m;

    int tot = 0;
    map<string, int> id;
    map<int, string> str;

    V<int> ans(m + 1);

    V<V<int>> panalty(26, V<int>(m + 1));
    V<V<val>> normal_val(26, V<val>(m + 1));
    V<V<val>> now_val(26, V<val>(m + 1));
    V<val> sum_val(m + 1);
    V<V<V<val>>> alt_val(26, V<V<val>>(m + 1)); 
    V<V<int>> cnt_ac(26, V<int>(m + 1));
    V<int> valid_team(m + 1);
    int cnt_valid = 0;
    V<int> teams;
    V<int> solved_cnt(m + 1);
    V<int> sp(m + 1);

    for(int i = 1; i <= m; i++) {
        string team; cin >> team;
        int teamid;
        if(!id.count(team)) id[team] = ++tot, str[tot] = team;
        teamid = id[team];

        teams.pb(teamid);
        char c; int time; string stname;
        cin >> c >> time >> stname;
        c -= 'A';
        int st;
        if(stname == "accepted") st = 1;
        else st = 0;

        time += panalty[c][teamid];

        if(st && cnt_ac[c][teamid] == 0) {
            if(!valid_team[teamid]) {
                cnt_valid++;
                valid_team[teamid] = 1;
            }
            solved_cnt[teamid]++;
            normal_val[c][teamid] = now_val[c][teamid] = {1, time};
            sum_val[teamid] = sum_val[teamid] + normal_val[c][teamid];
        }
        if(cnt_ac[c][teamid] == 0 || cnt_ac[c][teamid] == 1 && st) {
            alt_val[c][teamid].pb({1, time});
        }

        cnt_ac[c][teamid] += st;
        panalty[c][teamid] += 20;
    }

    for(int i = 0; i < 26; i++) {
        for(auto name : teams) {
            if(cnt_ac[i][name] == 1) alt_val[i][name].pb({0, 0});
        }
    }

    set<pair<val, int>> cur;
    for(auto name : teams) {
        cur.insert({sum_val[name], name}); 
    }

    int test = 0;
    int cnt_cal_ans = 0;
    auto cal_ans = [&]() -> void {
        cnt_cal_ans++;
        assert(cnt_cal_ans <= 2 * m);
        int x = min(35, (cnt_valid + 9) / 10);
        if(x == 0) return;

        auto it = cur.begin();
        for(int i = 1; i <= x; i++) {
            ans[it->se] = 1;
            it++;
        }
        if(test) {
            if(!(prev(it)->fi < sum_val[test])) {
                ans[test] = 1;
            }
        }
        while(it != cur.end() && it->fi.num == prev(it)->fi.num && it->fi.time == prev(it)->fi.time) {
            ans[it->se] = 1;
            sp[it->se]++;
            if(sp[it->se] >= 60) break;
            it++;
        }
    };

    cal_ans();

    int cnt_chg = 0;

    auto chg = [&](int name, int c, val v) -> void {
        cnt_chg++;
        assert(cnt_chg <= 2 * m);
        cur.erase({sum_val[name], name});
        val pv = now_val[c][name];
        now_val[c][name] = v;

        if(solved_cnt[name]) valid_team[name] = 0, cnt_valid--;
        solved_cnt[name] -= pv.num;
        solved_cnt[name] += v.num;
        if(solved_cnt[name]) valid_team[name] = 1, cnt_valid++;
        sum_val[name] = sum_val[name] - pv;
        sum_val[name] = sum_val[name] + v;

        cur.insert({sum_val[name], name});
        test = name;
    };

    for(int i = 0; i < 26; i++) {
        for(auto name : teams) {
            if(alt_val[i][name].empty()) continue;
            for(auto v : alt_val[i][name]) {
                chg(name, i, v);
                cal_ans();
            }
            chg(name, i, normal_val[i][name]);
        }
    }

    cout << accumulate(all1(ans), 0LL) << endl;
    for(int i = 1; i <= m; i++) {
        if(ans[i]) cout << str[i] << " ";
    }
    cout << endl;
}

int32_t main() {
    ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    int t = 1;
    cin >> t;
    while (t--) 
    solve();
}

详细

Test #1:

score: 0
Runtime Error

input:

2
5
TSxingxing10 G 0 rejected
TSxingxing10 B 83 accepted
aoliaoligeiliao J 98 accepted
TS1 J 118 accepted
TS1 B 263 accepted
12
AllWayTheNorth A 0 rejected
YaoYaoLingXian Y 10 accepted
XuejunXinyoudui1 X 200 rejected
XuejunXinyoudui1 X 200 accepted
LetItRot L 215 accepted
AllWayTheNorth W 250 accept...

output:


result: