统计单词个数
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
using namespace std;
char ss[7][210],s[210];
int n,k,m,len[7],f[210][41],d[210],w[210][210];
int main()
{
scanf("%d%d",&n,&k);
for(int i=0;i<n;i++)scanf("%s",&s[1+i*20]);
n*=20;
scanf("%d",&m);
for(int i=1;i<=m;i++){
scanf("%s",ss[i]);
len[i]=strlen(ss[i]);
}
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
if((!strncmp(&s[i],ss[j],len[j]))&&((!d[i])||d[i]>len[j]))d[i]=len[j];
for(int i=1;i<=n;i++){
for(int j=i;j<=n;j++){
w[i][j]=w[i][j-1];
for(int l=i;l<=j;l++)
if(j-l+1==d[l])w[i][j]++;
}
}
for(int i=1;i<=k;i++)
for(int j=1;j<=n;j++)
for(int l=i-1;l<j;l++)
if(f[j][i]<f[l][i-1]+w[l+1][j])f[j][i]=f[l][i-1]+w[l+1][j];
printf("%d\n",f[n][k]);
return 0;
}
/*
1 3
thisisabookyouareaoh
4
is
a
ok
sab
*/

浙公网安备 33010602011771号