Submission #230701

#TimeUsernameProblemLanguageResultExecution timeMemory
230701Hrithik_NarangSplit the sequence (APIO14_sequence)C++14
0 / 100
2082 ms8192 KiB
#include<bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> // Common file #include <ext/pb_ds/tree_policy.hpp> #include <functional> // for less #define pb push_back #define For(i,s,e) for (ll i=(s); i<(e); i++) #define Debug_array(a,n) for (ll i=(0); i<(n); i++) cout<<a[i]<<" " #define Foe(i,s,e) for (ll i=(s); i<=(e); i++) #define Fod(i,s,e) for (ll i=(s)-1; i>=(e); i--) #define pii pair<ll,ll> #define fi first #define se second #define endl "\n" #define mp make_pair #define big_prime 15486277 #define bigger_prime 179424697 #define biggest_prime 32416188691 //#define random_shuffle(indices.begin(), indices.end()); //std::random_device rd; //std::mt19937 g(rd()); //std::shuffle(v.begin(), v.end(), g); using namespace __gnu_pbds; using namespace std; template <class T> ostream& operator << (ostream &os, const vector<T> &v) { for (T i : v) os << i << ' '; return os; } template <class T> ostream& operator << (ostream &os, const set<T> &v) { for (T i : v) os << i << ' '; return os; } template <class T, class S> ostream& operator << (ostream &os, const pair<T, S> &v) { os << v.first << ' ' << v.second; return os; } // template <class T, class S> ostream& operator << (ostream &os, const unordered_map<T, S> &v) { for (auto i : v) os << '(' << i.first << "=>" << i.second << ')' << ' '; return os; } #ifndef ONLINE_JUDGE #define trace(...) __f(#__VA_ARGS__, __VA_ARGS__) template <class Arg1> void __f(const char* name, Arg1&& arg1) { cerr << name << " : " << arg1 << endl; } template <class Arg1, class... Args> void __f(const char* names, Arg1&& arg1, Args&&... args) { const char* sep = strchr(names + 1, ','); cerr.write(names, sep - names) << " : " << arg1 << " "; __f(sep + 1, args...); } #else #define trace(...) 0 #define _CRT_SECURE_NO_WARNINGS #endif // ifndef ONLINE_JUDGE typedef long long ll; typedef tree<ll, null_type, less<ll>, rb_tree_tag,tree_order_statistics_node_update> ordered_set; #define Mod 1000000007 #define MAX 5002 int main(){ ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); ll n,K;cin>>n>>K; ll a[n],prefix[n]; For(i,0,n) { cin>>a[i]; prefix[i]=a[i]+(i>0 ? prefix[i-1] : 0); } ll dp[n][K+1]; ll next[n][K+1]; memset(dp,0,sizeof(dp)); memset(next,-1,sizeof(next)); Foe(k,1,K){ For(i,0,n-1){ For(j,i,n){ ll t = dp[j+1][k-1]+(prefix[j]-(i>0 ? prefix[i-1] : 0))*(prefix[n-1]-prefix[j]); if(t>=dp[i][k]){ dp[i][k]=t; next[i][k]=j; } } } } vector<ll> ans; ll c = 0 , k=K; while(k>0){ c = next[c][k]+1; ans.pb(c); k--; } cout<<dp[0][K]<<endl; For(i,0,(ll)ans.size()){ cout<<ans[i]<<" "; } cout<<endl; }
#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...