Submission #968133

#TimeUsernameProblemLanguageResultExecution timeMemory
968133berrPopeala (CEOI16_popeala)C++17
26 / 100
1136 ms262144 KiB
#include <bits/stdc++.h> using namespace std; const int N = 2e4+30; int r[N][N]; void solve(){ int n, t, s; cin >> n >> t >> s; vector<int> v(t); vector<vector<array<int, 2>>> g(t+1); vector dis(t+1, vector(s+2, (int)2e9)); for(auto &i: v) cin >> i; vector<string> se(n); for(auto &i: se){ cin >> i; int k=i[0]-'0'; for(int l=1; l<t; l++){ if(i[l]=='0'){ for(int j=l-k; j<l; j++){ for(int g=j; g<l; g++){ r[j][g]++; } } k=0; } else k++; } if(k){ for(int j=t-k; j<t; j++){ for(int g=j; g<t; g++){ r[j][g]++; } } } } for(int i=1; i<t; i++) v[i] += v[i-1]; for(int i=0; i<t; i++){ int ek=0; if(i>0) ek=v[i-1]; for(int l=i+1; l<t; l++){ g[i].push_back({l, (v[l-1]-ek)*r[i][l-1]}); } g[i].push_back({t, (v[t-1]-ek)*r[i][t-1]}); } priority_queue<array<int, 3>> pq; pq.push({0, 0, 0}); dis[0][0]=0; while(pq.size()){ auto [cos, ed, v]= pq.top(); pq.pop(); cos*=-1; if(cos != dis[v][ed]) continue; for(auto [i, c]: g[v]){ if(ed+1 <= s && cos+c < dis[i][ed+1]){ dis[i][ed+1]=cos+c; pq.push({-(cos+c), (ed+1), i}); } } } for(int i=1; i<=s; i++) cout<<dis[t][i]<<"\n"; } signed main(){ ios_base::sync_with_stdio(false); cin.tie(0); /*freopen("popeala.in", "r", stdin); freopen("popeala.out", "w", stdout); */ solve(); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...