# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
76534 | georgerapeanu | Popeala (CEOI16_popeala) | C++11 | 3 ms | 720 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <cstdio>
#include <algorithm>
#include <vector>
#include <deque>
using namespace std;
const int TMAX = 2e4;
const int NMAX = 50;
const int SMAX = 50;
const int INF = (1 << 29);
FILE *f = fopen("popeala.in","r");
FILE *g = fopen("popeala.out","w");
int t,n,s;
int points[TMAX + 5];
int preffix_sum[TMAX + 5];
char results[NMAX + 5][TMAX + 5];
int valid_from[NMAX + 5][TMAX + 5];
int dp[SMAX + 5][TMAX + 5];
int ant[NMAX + 5];
int nxt[NMAX + 5];
int st[NMAX + 5];
int dr[NMAX + 5];
deque< pair<int,int> > segment[NMAX + 5];
int main(){
fscanf(f,"%d %d %d\n",&n,&t,&s);
for(int i = 1;i <= t;i++){
fscanf(f,"%d",&points[i]);
preffix_sum[i] = preffix_sum[i - 1] + points[i];
}
fscanf(f,"\n");
for(int i = 1;i <= n;i++){
fgets(results[i] + 1,TMAX + 5,f);
}
for(int i = 1;i <= n;i++){
valid_from[i][0] = 1;
for(int j = 1;j <= t;j++){
valid_from[i][j] = (results[i][j] == '1' ? valid_from[i][j - 1]:j + 1);
}
}
for(int j = 1;j <= t;j++){
dp[0][j] = INF;
}
for(int i = 1;i <= s;i++){
for(int j = 0;j <= n;j++){
nxt[j] = j + 1;
ant[j] = j - 1;
st[j] = 1;
dr[j] = 1;
segment[j].clear();
}
ant[0] = n;
nxt[n] = 0;
dp[i][0] = INF;
for(int j = 1;j <= t;j++){
for(int k = 1;k <= n;k++){
if(valid_from[k][j] != valid_from[k][j - 1]){
nxt[ant[k]] = nxt[k];
ant[nxt[k]] = ant[k];
int head = ant[0];
nxt[k] = nxt[head];
ant[k] = head;
nxt[ant[k]] = k;
ant[nxt[k]] = k;
}
}
if(j < i){
dp[i][j] = INF;
continue;
}
vector<int> positions;
positions.push_back(1);
for(int nod = nxt[0];nod;nod = nxt[nod]){
positions.push_back(valid_from[nod][j]);
}
positions.push_back(j + 1);
dp[i][j] = INF;
for(int seg = n;seg >= 0;seg--){
while(dr[seg] < positions[seg + 1]){
int cost = dp[i - 1][dr[seg] - 1] - preffix_sum[dr[seg] - 1] * seg;
while(segment[seg].size() && segment[seg].back().second >= cost){
segment[seg].pop_back();
}
segment[seg].push_back({dr[seg],cost});
dr[seg]++;
}
while(st[seg] < positions[seg]){
while(segment[seg].size() && segment[seg].front().first <= st[seg]){
segment[seg].pop_front();
}
st[seg]++;
}
if(segment[seg].size()){
dp[i][j] = min(dp[i][j],segment[seg].front().second + preffix_sum[j] * seg);
}
}
}
fprintf(g,"%d\n",dp[i][t]);
}
return 0;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |