제출 #1068854

#제출 시각아이디문제언어결과실행 시간메모리
1068854Essa2006Fire (BOI24_fire)C++14
31 / 100
2099 ms1652 KiB
#include<bits/stdc++.h> using namespace std; #define ll long long #define endl '\n' #define FF first #define SS second #define all(a) a.begin(), a.end() #define mod (ll)(1000000007) int main() { ios_base::sync_with_stdio(0);cin.tie(0); int n, m; cin >> n >> m; vector<int> All; All.reserve(2 * n); vector<array<int, 2>> A(n); for (int i = 0; i < n; i++) { cin >> A[i][0] >> A[i][1]; All.push_back(A[i][0]); All.push_back(A[i][1]); } sort(all(All)); map<int, int> new_; int cnt = 0; for (int i = 0; i < All.size(); i++) { if (!i || All[i] != All[i - 1]) { new_[All[i]] = cnt++; } } int sz = cnt; for (int i = 0; i < n; i++) { A[i][0] = new_[A[i][0]], A[i][1] = new_[A[i][1]]; } int ans = n + 1; for (int k = 0; k < All.size(); k++) { if (k && All[k] == All[k - 1]) { continue; } int cur = new_[All[k]]; vector<array<int, 2>> B = A; vector<vector<int>> Events(sz + 1); for (int i = 0; i < n; i++) { if (A[i][0] >= cur) { A[i][0] -= cur; } else { A[i][0] += sz - cur; } if (A[i][1] >= cur) { A[i][1] -= cur; } else { A[i][1] += sz - cur; } if (A[i][0] > A[i][1]) { A[i][1] = sz; } Events[A[i][0]].push_back(i); Events[A[i][1]].push_back(i); } vector<int> Prf(sz + 1, n + 1), Suf(sz + 1, n + 1); Prf[0] = 0; for (int i = 1; i <= sz; i++) { for (auto j : Events[i]) { if (i != A[j][1]) { continue; } for (int f = A[j][0]; f <= A[j][1] - 1; f++) { Prf[i] = min(Prf[i], Prf[f] + 1); } //Prf[i] = min(Prf[i], get(0, A[j][0], A[j][1] - 1) + 1); } } Suf[sz] = 0; for (int i = sz; i >= 0; i--) { for (auto j : Events[i]) { if (i != A[j][0]) { continue; } for (int f = A[j][0] + 1; f <= A[j][1]; f++) { Suf[i] = min(Suf[i], Suf[f] + 1); } //Suf[i] = min(Suf[i], get(1, A[j][0] + 1, A[j][1]) + 1); } } for (int i = 1; i <= sz; i++) { Suf[i] = min(Suf[i], Suf[i - 1]); } for (int i = sz - 1; i >= 0; i--) { Prf[i] = min(Prf[i], Prf[i + 1]); } for (int i = 0; i <= sz; i++) { ans = min(ans, Prf[i] + Suf[i]); } A = B; } if (ans == n + 1) { ans = -1; } cout << ans; }

컴파일 시 표준 에러 (stderr) 메시지

Main.cpp: In function 'int main()':
Main.cpp:30:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   30 |     for (int i = 0; i < All.size(); i++) {
      |                     ~~^~~~~~~~~~~~
Main.cpp:42:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   42 |     for (int k = 0; k < All.size(); k++) {
      |                     ~~^~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...