제출 #1360323

#제출 시각아이디문제언어결과실행 시간메모리
1360323phungmanager0모임들 (IOI18_meetings)C++20
19 / 100
508 ms1092 KiB
#include "meetings.h"
#include <bits/stdc++.h>
#define FOR(i, a, b) for (int i = (a), _b = (b); i <= _b; i++)
#define FORD(i, b, a) for (int i = (b), _a = (a); i >= _a; i--)
#define REP(i, n) for (int i = 0, _n = (n); i < _n; i++)
#define FORE(i, v) for (__typeof((v).begin()) i = (v).begin(); i != (v).end(); i++)
#define ALL(v) (v).begin(), (v).end()
#define IS_INF(x)   (std::isinf(x))
#define IS_NAN(x)   (std::isnan(x))
#define fi   first
#define se   second
#define MASK(i) (1LL << (i))
#define BIT(x, i) (((x) >> (i)) & 1)
#define div   ___div
#define prev   ___prev
#define next   ___next
#define left   ___leftc
#define right   ___right
#define __Im_sogood__ main()
#define TIME  (1.0 * clock() / CLOCKS_PER_SEC)
#define __builtin_popcount __builtin_popcountll
using namespace std;
const int MAXN = 2e5 + 5;
const long long INF = 1e18;
int n, q;
vector<long long> solve_subtask1(const vector<int>& H, const vector<int>& L, const vector<int>& R) {
    vector<long long> answer; REP(i, q) {
        int l = L[i], r = R[i]; long long ans = INF; FOR(j, l, r) {
            long long res = H[j], mx = H[j]; FORD(k, j - 1, l) { mx = max(mx, (long long)H[k]); 
            res += mx; }
            mx = H[j]; FOR(k, j + 1, r) { mx = max(mx, (long long)H[k]); res += mx; }
            ans = min(ans, res);
        }
        answer.push_back(ans);
    }
    return answer;
}
// left[x]: sum i < x
// right[x]: sum i > x;
vector<long long> solve_subtask2Stack(const vector<int>& H, const vector<int>& L, const vector<int>& R) {
    vector<long long> answer; vector<long long> left(n, 0), right(n, 0);
    REP(i, q) {
        int l = L[i], r = R[i]; long long ans = INF; stack<pair<long long, long long>> st;
        st.push({H[l], 1ll}); long long sum = H[l]; FOR(j, l + 1, r) {
            long long cur = 0;
            while(st.size() && st.top().first <= H[j]) {
                cur += st.top().second; sum -= st.top().second * st.top().first;
                st.pop();
            }
            cur++;
            sum += cur * H[j]; st.push({H[j], cur});
            left[j] = sum - H[j];
        }
        while(st.size()) st.pop();
        st.push({H[r], 1}); sum = H[r]; FORD(j, r - 1, l) {
            long long cur = 0; while(st.size() && st.top().first <= H[j]) {
                cur += st.top().second; sum -= st.top().second * st.top().first;
                st.pop();
            }
            cur++; sum += cur * H[j]; st.push({H[j], cur});
            right[j] = sum - H[j];
        }
        FOR(j, l, r) ans = min(ans, left[j] + right[j] + H[j]); answer.push_back(ans);
        REP(i, n) left[i] = right[i] = 0;
    }
    return answer;
}
/*vector<long long> solve_subtask2DP(const vector<int>& H, const vector<int>& L, const vector<int>& R) {

}*/
vector<long long> minimum_costs(vector<int> H, vector<int> L, vector<int> R) {
    n = (int)H.size(); q = (int)L.size(); 
    //return solve_subtask1(H, L, R);
    //return solve_subtask2Stack(H, L, R);
    if(n <= 3000 && q<= 10) return solve_subtask1(H, L, R);
    else if(n <= 5000 && q <= 5000) return solve_subtask2Stack(H, L, R);
    return {};
}
/*void read_fake_input() {
    int n, q; vector<int> H, L, R; cin >> n >> q; REP(i, n) {
        int x; cin >> x; H.push_back(x);
    } REP(i, q) { int x; cin >> x; L.push_back(x); } REP(i, q) {
        int x; cin >> x; R.push_back(x);
    }
    vector<long long> res = minimum_costs(H, L, R); FORE(it, res) cout << (*it) << "\n";
}
__Im_sogood__{
    //freopen("udt.inp", "r", stdin);
    //freopen("udt.ans", "w", stdout);
    ios_base::sync_with_stdio(0);
    cin.tie(0); cout.tie(0);
    read_fake_input();
    cerr << "Time elapsed: " << TIME << " s.\n";
    return 0;
}*/
#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...