Codeforces 494B. Obsessive String KMP+DP
来源:互联网 发布:英语直译软件 编辑:程序博客网 时间:2024/05/17 02:45
dp[i]表示到第i个可以分的段数,dp[i]=dp[i-1]+ ( dp[j]+1 ) ( 0<=j<=near[i] ) near[i]是距离i最靠右的一个含有T串的位置
/* ***********************************************Author :CKbossCreated Time :2015年03月20日 星期五 19时30分59秒File Name :CF494B.cpp************************************************ */#include <iostream>#include <cstdio>#include <cstring>#include <algorithm>#include <string>#include <cmath>#include <cstdlib>#include <vector>#include <queue>#include <set>#include <map>using namespace std;const int maxn=100100;const int mod=1e9+7;char s[maxn],t[maxn];int fail[maxn];int near[maxn];int dp[maxn],sum[maxn];void getfail(char* p,int* f){int m=strlen(p);f[0]=f[1]=0;for(int i=1;i<m;i++){int j=f[i];while(j&&p[j]!=p[i]) j=f[j];f[i+1]=(p[i]==p[j])?j+1:0;}}void kmp(char* t,char* p,int* f){int n=strlen(t),m=strlen(p);getfail(p,f);int j=0;for(int i=0;i<n;i++){while(j&&p[j]!=t[i]) j=f[j];if(p[j]==t[i]) j++;if(j==m) { near[i+1]=i-m+2; j=f[j]; }}}int main(){ //freopen("in.txt","r",stdin); //freopen("out.txt","w",stdout);scanf("%s",s); scanf("%s",t);kmp(s,t,fail);int n=strlen(s),m=strlen(t);for(int i=1;i<=n;i++)if(near[i]==0) near[i]=near[i-1];for(int i=1;i<=n;i++){dp[i]=dp[i-1];if(near[i]){dp[i]=(dp[i]+sum[near[i]-1]+near[i])%mod;}sum[i]=(sum[i-1]+dp[i])%mod;}printf("%d\n",dp[n]); return 0;}
1 0
- Obsessive String - CodeForces 494 B KMP+dp
- Codeforces 494B. Obsessive String KMP+DP
- codeforces 494B B. Obsessive String(dp)
- codeforces 494B B. Obsessive String(dp)
- codeforces 494B Obsessive String
- CF494B Obsessive String(KMP+DP)
- codeforces#282 Obsessive String
- codeforces 494B kmp+dp
- codeforces 126B Password DP KMP
- codeforces 126B B. Password(kmp+dp)
- [Codeforces 176B] Word Cut (脑洞+KMP+dp)
- Educational Codeforces Round 25 F. String Compression(kmp+dp)
- CodeForces 825F String Compression---这个KMP很DP
- Codeforces 6225B KMP
- Codeforces 625B【KMP】
- codeforces 126B Password KMP
- Codeforces 126B Password(KMP)
- codeforces 126B password KMP
- C#中的值参数,引用参数及输出参数
- iPhone Tethering
- POJ 1664 放苹果
- JAVA基础编程50题(13-15题)详解
- 算法训练 结点选择 (树形DP)
- Codeforces 494B. Obsessive String KMP+DP
- 泛型第一课,自定义泛型,泛型类,泛型接口,泛型的方法
- 面向对象的封装与继承
- Android 使用动态加载框架DL进行插件化开发
- 每日一题3:判断单链表是否相交
- ModelSim仿真流程
- 【Visual C++】游戏编程学习笔记之九:回合制游戏demo(剑侠客VS巡游天神)
- nyoj 60 谁获得了最高奖学金
- 解译密码