【hiho一下 第三周】KMP算法
2024-10-01 06:40:36
【题目链接】:http://hihocoder.com/problemset/problem/1015
【题意】
【题解】
把f数组,len1,len2数组一开始全都定义成char型
这酸爽.
【Number Of WA】
3
【完整代码】
#include <cstdio>
#include <cstring>
#include <cmath>
#include <iostream>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define ms(x,y) memset(x,y,sizeof x)
typedef pair<int,int> pii;
typedef pair<LL,LL> pll;
const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 1e6+100;
char s1[N],s2[N];
int f[N],len1,len2;
int main()
{
//freopen("F:\\rush.txt","r",stdin);
int t;
cin >> t;
while (t--)
{
int ans = 0;
scanf("%s",s1);
scanf("%s",s2);
len1 = strlen(s1),len2 = strlen(s2);
f[0] = f[1] = 0;
rep1(i,1,len1-1)
{
int j = f[i];
while (j && s1[i]!=s1[j]) j = f[j];
f[i+1]=(s1[i]==s1[j])?(j+1):0;
}
int j = 0;
rep1(i,0,len2-1)
{
while (j && s2[i]!=s1[j]) j = f[j];
if (s2[i]==s1[j])
{
j++;
if (j==len1)
{
ans++;
j = f[j];
}
}
}
cout << ans << endl;
}
return 0;
}
最新文章
- C#的DataTable操作方法
- 【圣诞呈献】高性能 Socket 组件 HP-Socket v3.1.1 正式发布
- MVC学习系列1--什么是MVC
- 5.开发webservice
- [SQL]收缩数据库日志
- 用Lambda表达式操作List集合
- ServletContext与application的关系
- Mybatis 打开连接池和关闭连接池性能对比
- C++ XML 解释库
- 对于windows窗口的标题菜单栏的操作——删除/禁用 最小最大话和关闭
- Semaphore初探
- VB6之SendMessage模拟拖放事件
- appium python api收集
- zw字王《中华大字库》2018版升级项目正式启动
- CAS工程用redis集群存储票据ticket Spring整合
- 洛谷P2278操作系统
- Mongo数据库基本操作
- January 21st, 2018 Week 3rd Sunday
- 关于asp.net mvc中的httpModules 与 httpHandler
- linux 环境变量设置方法总结(PATH / LD_LIBRARY_PATH)