首页 > 其他 > 详细

[Luogu] 子串

时间:2018-04-28 18:36:54      阅读:164      评论:0      收藏:0      [点我收藏+]

https://www.luogu.org/problemnew/show/P2679

DP

f(k,i,j)f(k,i,j)表示分了k段,用了第一个串中的前i个数字,已经构成了第二个串的前j个的方案数

f(k,i,j)={f(k1,l,j1)f(k1,l,j1)+f(k,i1,j1)s1[i]==s2[j]s1[i1]!=s2[j1]s1[i]==s2[j]s1[i1]==s2[j1]0<l<i0<l<i
#include<iostream>

long long f[201][201] = {1}, sum[201][201], n, m, ki;

char a[1001], b[201];

int main() {
    std:: cin >> n >> m >> ki >> a >> b;
    for(int i = 1; i <= n; i ++)
        for(int j = m; j >= 1; j --)
            for(int k = ki; k >= 1; k --)
                f[j][k] = (f[j][k] + (sum[j][k] = a[i - 1] == b[j-1] ? 
                            sum[j - 1][k] + f[j - 1][k - 1] : 0)) % 1000000007;
    std:: cout << f[m][ki];
}

 

[Luogu] 子串

原文:https://www.cnblogs.com/shandongs1/p/8968884.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!