제출 #1069268

#제출 시각아이디문제언어결과실행 시간메모리
1069268Essa2006Fire (BOI24_fire)C++14
31 / 100
2093 ms1648 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);
        vector<array<int, 2>> Stk;
        
        Prf[0] = 0;
        Stk.push_back({0, Prf[0]});  
        for (int i = 1; i <= sz; i++) {
            int mn = i;
            for (auto j : Events[i]) {
                if (i != A[j][1]) {
                    continue;
                }
                
                mn = min(mn, A[j][0]);
                
            }
            if (mn != i) {
                array<int, 2> kj = {mn, -1};
                array<int, 2> res = *lower_bound(all(Stk), kj);
                Prf[i] = min(Prf[i], res[1] + 1);
            }
            while (!Stk.empty() && Prf[i] <= Stk.back()[1]) {
                Stk.pop_back();
            }
            Stk.push_back({i, Prf[i]});
        }
        
        Stk.clear();
        Suf[sz] = 0;
        Stk.push_back({sz - sz, Suf[sz]});
        for (int i = sz; i >= 0; i--) {
            int mx = i;
            for (auto j : Events[i]) {
                if (i != A[j][0]) {
                    continue;
                }
                
                mx = max(mx, A[j][1]);
            }
            if (mx != i) {
                array<int, 2> kj = {sz - mx, -1};
                array<int, 2> res = *lower_bound(all(Stk), kj);
                Suf[i] = min(Suf[i], res[1] + 1);
            }
            while (!Stk.empty() && Suf[i] <= Stk.back()[1]) {
                Stk.pop_back();
            }
            Stk.push_back({sz - i, Suf[i]});
        }
        
        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]);
        }
        
        swap(A, B);
    }
    if (ans == n + 1) { 
        ans = -1;
    }
    cout << ans;
}

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

Main.cpp: In function 'int main()':
Main.cpp:31:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   31 |     for (int i = 0; i < All.size(); i++) {
      |                     ~~^~~~~~~~~~~~
Main.cpp:43:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   43 |     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...