# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
127647 | TadijaSebez | Popeala (CEOI16_popeala) | C++11 | 118 ms | 2808 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 <bits/stdc++.h>
using namespace std;
#define ll long long
const int K=52;
const int N=20050;
const ll inf=1e18;
int n,t,s;
ll dp[K][N],sum[K][N],pts[N];
ll Get(int l, int r)
{
ll s=pts[r]-pts[l-1],cnt=0;
for(int i=1;i<=n;i++)
{
if(sum[i][r]-sum[i][l-1]==r-l+1) cnt++;
}
return s*cnt;
}
void Solve(int x, int l, int r, int L, int R)
{
/*for(int i=l;i<=r;i++)
{
for(int j=L;j<=min(i,R);j++)
{
dp[x][i]=min(dp[x][i],dp[x-1][j-1]+Get(j,i));
}
}*/
if(l>r) return;
int mid=l+r>>1;
int opt=mid;
for(int i=L;i<=min(mid,R);i++)
{
if(dp[x][mid]>=dp[x-1][i-1]+Get(i,mid))
{
opt=i;
dp[x][mid]=dp[x-1][i-1]+Get(i,mid);
}
}
Solve(x,l,mid-1,L,opt);
Solve(x,mid+1,r,opt,R);
}
char res[K][N];
int main()
{
scanf("%i %i %i",&n,&t,&s);
for(int i=1;i<=t;i++) scanf("%lld",&pts[i]),pts[i]+=pts[i-1];
for(int i=1;i<=n;i++)
{
scanf("%s",res[i]+1);
for(int j=1;j<=t;j++) sum[i][j]=sum[i][j-1]+(res[i][j]=='1');
}
for(int i=0;i<=s;i++) for(int j=0;j<=t;j++) dp[i][j]=inf;
dp[0][0]=0;
for(int i=1;i<=s;i++) Solve(i,1,t,1,t);
for(int i=1;i<=s;i++) printf("%lld\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... |