统计单词个数

#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
*/


posted @ 2016-04-10 12:20  keshuqi  阅读(157)  评论(0编辑  收藏  举报