# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
1033104 | 2024-07-24T12:55:15 Z | borisAngelov | Long Mansion (JOI17_long_mansion) | C++17 | 230 ms | 25400 KB |
#include <bits/stdc++.h> using namespace std; const int maxn = 500005; int n, q; int a[maxn]; int l[maxn]; int r[maxn]; vector<int> keysPos[maxn]; bool isPossible(int leftPos, int rightPos, int key) { if (keysPos[key].empty()) return false; int pos = lower_bound(keysPos[key].begin(), keysPos[key].end(), leftPos) - keysPos[key].begin(); return pos < keysPos[key].size() && keysPos[key][pos] <= rightPos; } void fastIO() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); } int main() { fastIO(); cin >> n; for (int i = 1; i <= n - 1; ++i) { cin >> a[i]; } for (int i = 1; i <= n; ++i) { int cnt; cin >> cnt; for (int j = 1; j <= cnt; ++j) { int key; cin >> key; keysPos[key].push_back(i); } } for (int i = 1; i <= n; ++i) { l[i] = r[i] = i; cout << "on " << i << endl; while (true) { //cout << "left " << isPossible(l[i], r[i], a[l[i] - 1]) << "\n"; if (isPossible(l[i], r[i], a[l[i] - 1]) == true) { r[i] = max(r[i], r[l[i] - 1]); l[i] = l[l[i] - 1]; } else if (isPossible(l[i], r[i], a[r[i]]) == true) { ++r[i]; } else { break; } } //cout << i << " -> " << l[i] << " " << r[i] << endl; } cin >> q; for (int i = 1; i <= q; ++i) { int x, y; cin >> x >> y; if (l[x] <= y && y <= r[x]) { cout << "YES\n"; } else { cout << "NO\n"; } } return 0; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 10 ms | 12380 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 10 ms | 12380 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 230 ms | 25400 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 10 ms | 12380 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |