Submission #1180402

#TimeUsernameProblemLanguageResultExecution timeMemory
1180402altern23K blocks (IZhO14_blocks)C++17
100 / 100
120 ms4944 KiB
#include <bits/stdc++.h> using namespace std; #define ll long long #define pii pair<ll, ll> #define fi first #define sec second #define ld long double const int MAXN = 1e6; const ll INF = 4e18; const int MOD = 998244353; int main(){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int tc = 1; // cin >> tc; for(;tc--;){ ll N, K; cin >> N >> K; vector<ll> a(N + 5), lf(N + 5, 1), rg(N + 5, N); for(int i = 1; i <= N; i++) cin >> a[i]; vector<ll> dp(N + 5, INF); dp[0] = 0; for(int i = 1; i <= K; i++){ stack<pii> stk; vector<ll> ndp(N + 5, INF); for(int j = 1; j <= N; j++){ ll cur = dp[j - 1]; while(!stk.empty() && a[stk.top().fi] <= a[j]){ cur = min(cur, stk.top().sec); stk.pop(); } // bikin segment baru ndp[j] = cur + a[j]; // gabung dengan segment sebelumnya if(!stk.empty()) ndp[j] = min(ndp[j], ndp[stk.top().fi]); stk.push({j, cur}); } dp.swap(ndp); } cout << dp[N] << "\n"; } } /* 1 2 3 4 5 6 7 */
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...