哈哈哈
查看原帖
哈哈哈
31294
功在不舍楼主2020/12/4 16:04

O(nm2k)O(nm^2k)居然能不吸O2硬艹过去

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,m,t,dp[1005][205][2],f[1005][205][2],ans,cur;
const int p=1e9+7;
char s1[1005],s2[1005];
int main()
{
	scanf("%d%d%d %s %s",&n,&m,&t,s1+1,s2+1);
	for(int i=0;i<=n;i++)dp[i][0][0]=f[i][0][0]=1;
	for(int k=1;k<=t;k++)
	{
		cur^=1;//cout<<cur<<endl;
		for(int i=0;i<=n;i++)
			for(register int j=0;j<=m;j++)
				dp[i][j][cur]=f[i][j][cur]=0;
		for(int i=1;i<=n;i++)
		{
			for(int j=1;j<=min(i,m);j++)
			{
				for(register int l=1;l<=j;l++)
					if(s1[i-l+1]==s2[j-l+1])//注意j必须固定,但是i可没必要固定 
						(dp[i][j][cur]+=f[i-l][j-l][cur^1])%=p;
					else break;
				f[i][j][cur]=(f[i-1][j][cur]+dp[i][j][cur])%p;
			}//f[i][j][k]=dp[1][j][k]+dp[2][j][k]+...... 
		}
	}
	for(int i=1;i<=n;i++)
			(ans+=dp[i][m][cur])%=p;
	cout<<ans<<endl;
	return 0;
}
2020/12/4 16:04
加载中...