O(nm2k)居然能不吸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;
}