Codeforces 625B - War of the Corporations
2016-02-09 12:33
288 查看
625B - War of the Corporations
分析:KMP,找出模式串在主串中出现的位置,然后总的个数减去重叠的个数就行#include <iostream>
#include <cstring>
using namespace std;
const int N = 100002;
int next[33];
char S
, T[33];
int slen, tlen;
int a
,cnt;
void getNext()
{
int j, k;
j = 0; k = -1; next[0] = -1;
while(j < tlen)
if(k == -1 || T[j] == T[k])
next[++j] = ++k;
else
k = next[k];
}
void KMP_Index()
{
int i = 0, j = 0;
getNext();
while(1){
while(i < slen && j < tlen)
{
if(j == -1 || S[i] == T[j])
{
i++; j++;
}
else
j = next[j];
}
if(j == tlen)
a[cnt++]=i-tlen,j=0;
if(i>=slen)break;
}
}
int main()
{
int TT;
int i, cc;
cin>>S>>T;
slen = strlen(S);
tlen = strlen(T);
cnt=0;
KMP_Index();
int ans=0;
for( i=0;i<cnt;){
int k=a[i]+tlen-1;
i++;
while(i<cnt&&a[i]<=k)i++,ans++;
}
cout<<cnt-ans<<endl;
return 0;
}
相关文章推荐
- Scala 中object和class的区别
- cocos2d-x特效之CCControlPotentiometer
- 拓薪教育-中国移动电商实战项目-任亮
- Shiro 学习笔记(3)—— 授权初步
- Cas(01)——简介
- 第一章 Java代码执行流程
- 学习sed,awk最好的路径
- 虚拟机的创建
- NGINX301 REWRITE官方博客文档
- viewpager立方体切换效果
- SPICE协议之ImageCache
- 【Linux相关】linux大文件分割与合并
- poj 1703 Find them, Catch them(Dsu)
- cocos2d-x Loading界面实现资源加载
- 高并发的核心技术-幂等的实现方案
- HDU 2046 骨牌铺方格(递推)
- YTU 2558: 游起来吧!超妹!
- YTU 2556: 空洞
- Android2D绘图基础
- YTU 2555: 老大的烦恼