Submission #1307908

#TimeUsernameProblemLanguageResultExecution timeMemory
1307908sakkaCat Exercise (JOI23_ho_t4)C++20
41 / 100
40 ms9576 KiB
#include <bits/stdc++.h>
#define ll long long
#define fi first
#define sec second
#define pb push_back
#define pll pair<ll,ll>
#define pii pair<int,int>
using namespace std;
void fr(){
    freopen("input.txt", "r", stdin);
    freopen("output.txt", "w", stdout);
}
const ll INF = 1e18;
int n, m;
vector<ll> dp(2e5+2), kiri(2e5+2), kanan(2e5+2);
vector<pll> h(2e5+2);

bool cmp(pll a, pll b){
    return a.fi > b.fi;
}
void solve(){
    cin >> n;
    for(int i=1; i<=n; i++){
        cin >> h[i].fi;
        h[i].sec = i;
    }
    vector<ll> st;
    for(int i=1; i<=n; i++){
        auto [x, idx] = h[i];
        while(st.size() && h[st.back()].fi < x){
            kanan[st.back()] = idx;
            st.pop_back();
        }
        st.pb(idx);
    }
    st.clear();
    for(int i=n; i>=1; i--){
        auto [x, idx] = h[i];
        while(st.size() && h[st.back()].fi < x){
            kiri[st.back()] = idx;
            st.pop_back();
        }
        st.pb(idx);
    }
    sort(h.begin()+1, h.begin()+n+1, cmp);
    ll mx = 0;
    dp[0] = -INF;
    for(int i=2; i<=n; i++){
        auto [x, idx] = h[i];
        dp[idx] = max(dp[kanan[idx]] + abs(idx - kanan[idx]), dp[kiri[idx]] + abs(idx - kiri[idx]));
        // cout << idx << " " << kiri[idx] << " " << kanan[idx] << endl;
        // cout << idx << " " << dp[idx] << endl;
        mx = max(mx, dp[idx]);
    }
    cout << mx << endl;
}

int main(){
    ios_base :: sync_with_stdio(0); cin.tie(0); cout.tie(0);
    // fr();
    solve();
}

Compilation message (stderr)

Main.cpp: In function 'void fr()':
Main.cpp:10:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   10 |     freopen("input.txt", "r", stdin);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
Main.cpp:11:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   11 |     freopen("output.txt", "w", stdout);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...