Submission #564220

#TimeUsernameProblemLanguageResultExecution timeMemory
564220Rafi22Popeala (CEOI16_popeala)C++14
100 / 100
776 ms18872 KiB
#include <bits/stdc++.h> using namespace std; #define endl '\n' #define st first #define nd second #define pb push_back #define sz(x) (int)(x).size() #define all(x) (x).begin(), (x).end() #define ll long long ll mod=1000000007; int inf=1000000007; ll infl=1000000000000000007; ll DP[57][20007]; ll mn[57][20007]; string is[57]; ll a[20007]; ll suf[20007]; bool was[57]; int main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int n,t,s; cin>>n>>s>>t; for(int i=1;i<=s;i++) cin>>a[i]; for(int i=s;i>0;i--) suf[i]=suf[i+1]+a[i]; for(int i=1;i<=n;i++) cin>>is[i]; for(int l=0;l<=n;l++) { for(int i=0;i<=s;i++) mn[l][i]=suf[1]*(ll)l; } for(int j=1;j<=t;j++) { vector<pair<int,int>>V; for(int i=1;i<=s;i++) { for(int l=1;l<=n;l++) if(is[l][i-1]=='0') V.pb({i,l}); vector<pair<int,int>>V1; int c=n; for(int l=1;l<=n;l++) was[l]=0; DP[j][i]=infl; DP[j][i]=min(DP[j][i],mn[c][i-1]-suf[i+1]*(ll)c); while(sz(V)>0) { if(!was[V.back().nd]) { was[V.back().nd]=1; V1.pb(V.back()); c--; DP[j][i]=min(DP[j][i],mn[c][V.back().st-1]-suf[i+1]*(ll)c); } V.pop_back(); } reverse(all(V1)); V=V1; } for(int l=0;l<=n;l++) { mn[l][0]=infl; for(int i=1;i<=s;i++) mn[l][i]=min(mn[l][i-1],DP[j][i]+suf[i+1]*(ll)l); } } for(int i=1;i<=t;i++) cout<<DP[i][s]<<endl; 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...