답안 #735772

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
735772 2023-05-04T15:43:52 Z sheldon Segway (COI19_segway) C++14
0 / 100
68 ms 360 KB
#include <bits/stdc++.h>

using namespace std;

// #pragma GCC optimize ("unroll-loops")

int position[20005], speed[20005][3], charge[20005], ans[20005], boost[20005];
bool acc[20005], finished[20005];

void solve() {
    int n;
    cin >> n;
    for (int i = 0; i < n; ++i) {
        cin >> speed[i][0] >> speed[i][1] >> speed[i][2];
        ans[i] = 1e9;
    }
    int m;
    cin >> m;
    for (int i = 0; i < m; ++i) {
        int x;
        cin >> x;
        acc[x] = 1;
    }
    for (int sec = 1; sec <= 15000; ++sec) {
        for (int i = 0; i < n; ++i) {
            if (finished[i]) continue;
            if (boost[i]) {
                --boost[i];
                ++position[i];
                continue;
            }
            int use = (position[i]) / 100;
            ++charge[i];
            if (charge[i] == speed[i][use]) {
                ++position[i];
                charge[i] = 0;
            }
        }
        // cout << sec << ' ' << position[0] << '\n';
        vector<int> people[301];
        for (int i = 0; i < n; ++i) {
            if (position[i] == 300) {
                finished[i] = 1;
                ans[i] = min(ans[i], sec);
            }
            people[position[i]].push_back(i);
        }
        int found = 0;
        for (int i = 300; i >= 1; --i) {
            if (acc[i]) {
                for (int x : people[i]) {
                    if (!boost[x]) {
                        boost[x] = found % 20;
                    }
                }
            }
            found += people[i].size();
        }
    }
    for (int i = 0; i < n; ++i) {
        cout << ans[i] << '\n';
    }
}

int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    solve();
}
# 결과 실행 시간 메모리 Grader output
1 Correct 15 ms 340 KB Output is correct
2 Incorrect 68 ms 340 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 16 ms 360 KB Output is correct
2 Correct 22 ms 340 KB Output is correct
3 Incorrect 23 ms 352 KB Output isn't correct
4 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 15 ms 340 KB Output is correct
2 Incorrect 68 ms 340 KB Output isn't correct
3 Halted 0 ms 0 KB -