统计单词个数
#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 */