标签:dp
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
char s[110];
int f[110][110];
int flag;
void check(int l,int p,int r)
{
if((r-p)%(p-l+1)!=0)return;
int lenth=p-l+1;
for(int i=p+1;i<=r;i++)
{
if(s[i]!=s[(i-l)%lenth+l])return;
}
flag=1;
}
int main()
{
memset(f,0x3f,sizeof(f));
scanf("%s",s+1);
int len=strlen(s+1);
for(int i=1;i<=len;i++)f[i][i]=1;
for(int l=2;l<=len;l++)
{
for(int i=1;i+l-1<=len;i++)
{
int j=i+l-1;
for(int k=i;k<j;k++)
{
f[i][j]=min(f[i][j],f[i][k]+f[k+1][j]);
flag=0;
check(i,k,j);
if(flag)
{
int tmp=f[i][k]+2;
int bit=(j-k)/(k-i+1)+1;
while(bit)bit/=10,tmp++;
f[i][j]=min(f[i][j],tmp);
}
}
}
}
printf("%d\n",f[1][len]);
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
BZOJ 1090 [SCOI2003]字符串折叠 区间DP
标签:dp
原文地址:http://blog.csdn.net/wzq_qwq/article/details/47046351