83062024-01-14 15:12:27anonTanúk (45 pont)cpp17Partially correct 9/45101ms25680 KiB
#include <bits/stdc++.h>
#define all(x) (x).begin(), (x).end()
#define FastIO ios::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL)
using namespace std;
typedef long long ll;
int main() {
    FastIO;
    bool flag;
    ll i, j, k, mh, N, H, K;
    cin >> N >> H >> K;
    set<ll> tsss;
    vector<array<ll, 2>> guests(N);
    for(i = 0; i < K; i++) {
        cin >> k;
        tsss.insert(k);
    }
    for(i = 0; i < N; i++)
        cin >> guests[i][0] >> guests[i][1];
    K = tsss.size();
    vector<ll> tss(K);
    i = 0;
    for(const auto &x : tsss)
        tss[i++] = x;
    vector<array<vector<ll>, 2>> eps(H + 1);
    for(i = 0; i < N; i++) {
        for(j = 0; j < 2; j++)
            eps[guests[i][j]][j].push_back(i);
    }
    unordered_set<ll> here;
    unordered_set<ll> lc;
    vector<ll> ans;
    j = 0;
    for(i = 1; i <= H; i++) {
        for(const auto &x : eps[i][0])
            here.insert(x);
        if(i == tss[j]) {
            if(ans.empty())
                lc = here;
            else {
                for(const auto &x : here) {
                    if(guests[ans.back()][1] < guests[x][0]) {
                        lc = here;
                        break;
                    }
                }
            }
            j++;
        }
        flag = !lc.empty();
        if(flag) {
            flag = false;
            for(const auto &x : eps[i][1]) {
                if(lc.find(x) != lc.end()) {
                    flag = true;
                    break;
                }
            }
        }
        if(flag) {
            mh = *(here.begin());
            for(const auto &x : here) {
                if(guests[mh][1] < guests[x][1])
                    mh = x;
            }
            ans.push_back(mh);
            j = upper_bound(all(tss), guests[mh][1]) - tss.begin();
            lc.clear();
        }
        for(const auto &x : eps[i][1])
            here.erase(x);
    }
    cout << ans.size() << '\n';
    for(const auto &x : ans)
        cout << x + 1 << ' ';
    cout << '\n';
    return 0;
}
SubtaskSumTestVerdictTimeMemory
base9/45
1Accepted0/03ms1824 KiB
2Accepted0/037ms12484 KiB
3Accepted2/235ms12656 KiB
4Accepted2/23ms3264 KiB
5Accepted2/23ms3104 KiB
6Partially correct1/24ms3764 KiB
7Wrong answer0/24ms4020 KiB
8Wrong answer0/24ms3972 KiB
9Wrong answer0/24ms7744 KiB
10Wrong answer0/24ms5016 KiB
11Wrong answer0/27ms8136 KiB
12Wrong answer0/28ms8260 KiB
13Wrong answer0/28ms8908 KiB
14Wrong answer0/28ms6636 KiB
15Wrong answer0/29ms6984 KiB
16Wrong answer0/210ms9968 KiB
17Wrong answer0/254ms17936 KiB
18Wrong answer0/276ms18600 KiB
19Wrong answer0/268ms17356 KiB
20Accepted2/272ms17740 KiB
21Wrong answer0/271ms19636 KiB
22Wrong answer0/282ms22236 KiB
23Wrong answer0/281ms22576 KiB
24Wrong answer0/3101ms25680 KiB