码迷,mamicode.com
首页 > 其他好文 > 详细

[Luogu] 子串

时间:2018-04-28 19:31:53      阅读:129      评论:0      收藏:0      [点我收藏+]

标签:targe   nal   data-   tin   cin   std   div   style   bsp   

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] 子串

标签:targe   nal   data-   tin   cin   std   div   style   bsp   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!