250292026-02-17 14:12:50sscrazyyFagyasztócpp17Hibás válasz 30/7534ms536 KiB
// Freezer — Greedy Approach O(N² log N)
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main() {
    int n;
    cin >> n;
    vector<int> s(n), m(n);
    for (int i = 0; i < n; i++) cin >> s[i] >> m[i];

    vector<bool> used(n, false);
    vector<pair<int,int>> result;
    int day = 1;

    while (true) {
        // Collect available meals: not used, quality >= 4, not expired
        vector<int> avail;
        for (int i = 0; i < n; i++)
            if (!used[i] && m[i] >= 4 && s[i] >= day)
                avail.push_back(i);

        // Sort by expiry (eat soonest-expiring first)
        sort(avail.begin(), avail.end(),
            [&](int a, int b){ return s[a] < s[b]; });

        // Try to find a valid pair
        bool found = false;
        for (int i = 0; i < (int)avail.size() && !found; i++)
            for (int j = i+1; j < (int)avail.size() && !found; j++)
                if (m[avail[i]] + m[avail[j]] >= 9) {
                    used[avail[i]] = used[avail[j]] = true;
                    result.push_back({avail[i]+1, avail[j]+1});
                    found = true;
                }
        if (!found) break;
        day++;
    }

    cout << result.size() << endl;
    for (auto& [a, b] : result)
        cout << a << " " << b << "\n";
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva1ms316 KiB
subtask210/10
2Elfogadva1ms316 KiB
3Elfogadva1ms508 KiB
4Elfogadva1ms316 KiB
5Elfogadva1ms316 KiB
6Elfogadva1ms316 KiB
7Elfogadva1ms316 KiB
8Elfogadva1ms316 KiB
9Elfogadva1ms316 KiB
10Elfogadva1ms316 KiB
11Elfogadva1ms316 KiB
subtask320/20
12Elfogadva1ms368 KiB
13Elfogadva1ms316 KiB
14Elfogadva1ms316 KiB
15Elfogadva1ms316 KiB
16Elfogadva1ms316 KiB
17Elfogadva1ms316 KiB
18Elfogadva2ms316 KiB
19Elfogadva1ms316 KiB
20Elfogadva1ms316 KiB
21Elfogadva4ms372 KiB
22Elfogadva1ms324 KiB
23Elfogadva17ms412 KiB
24Elfogadva17ms424 KiB
25Elfogadva8ms316 KiB
26Elfogadva1ms316 KiB
27Elfogadva14ms424 KiB
28Elfogadva34ms424 KiB
29Elfogadva3ms316 KiB
30Elfogadva4ms316 KiB
31Elfogadva17ms508 KiB
subtask40/15
32Elfogadva1ms512 KiB
33Elfogadva1ms316 KiB
34Elfogadva1ms316 KiB
35Hibás válasz1ms316 KiB
36Elfogadva3ms316 KiB
37Elfogadva3ms316 KiB
38Hibás válasz1ms316 KiB
39Elfogadva2ms316 KiB
40Elfogadva2ms508 KiB
41Elfogadva8ms416 KiB
42Elfogadva3ms316 KiB
43Hibás válasz16ms508 KiB
44Elfogadva1ms500 KiB
45Elfogadva4ms404 KiB
46Elfogadva17ms316 KiB
subtask50/15
47Elfogadva1ms508 KiB
48Elfogadva2ms316 KiB
49Hibás válasz2ms512 KiB
50Elfogadva1ms316 KiB
51Elfogadva3ms508 KiB
52Elfogadva1ms316 KiB
53Hibás válasz1ms316 KiB
54Elfogadva2ms316 KiB
55Elfogadva1ms512 KiB
56Elfogadva3ms316 KiB
57Elfogadva2ms316 KiB
58Hibás válasz1ms316 KiB
59Hibás válasz2ms316 KiB
60Elfogadva1ms376 KiB
61Elfogadva1ms316 KiB
subtask60/15
62Hibás válasz3ms500 KiB
63Elfogadva4ms316 KiB
64Elfogadva10ms536 KiB
65Hibás válasz25ms416 KiB
66Elfogadva28ms428 KiB
67Elfogadva1ms316 KiB
68Hibás válasz4ms316 KiB
69Hibás válasz2ms316 KiB
70Hibás válasz3ms316 KiB
71Hibás válasz14ms424 KiB
72Elfogadva2ms500 KiB
73Hibás válasz7ms316 KiB
74Elfogadva9ms416 KiB
75Elfogadva3ms316 KiB
76Elfogadva1ms400 KiB