【题目链接】: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;
}

最新文章

  1. C#的DataTable操作方法
  2. 【圣诞呈献】高性能 Socket 组件 HP-Socket v3.1.1 正式发布
  3. MVC学习系列1--什么是MVC
  4. 5.开发webservice
  5. [SQL]收缩数据库日志
  6. 用Lambda表达式操作List集合
  7. ServletContext与application的关系
  8. Mybatis 打开连接池和关闭连接池性能对比
  9. C++ XML 解释库
  10. 对于windows窗口的标题菜单栏的操作——删除/禁用 最小最大话和关闭
  11. Semaphore初探
  12. VB6之SendMessage模拟拖放事件
  13. appium python api收集
  14. zw字王《中华大字库》2018版升级项目正式启动
  15. CAS工程用redis集群存储票据ticket Spring整合
  16. 洛谷P2278操作系统
  17. Mongo数据库基本操作
  18. January 21st, 2018 Week 3rd Sunday
  19. 关于asp.net mvc中的httpModules 与 httpHandler
  20. linux 环境变量设置方法总结(PATH / LD_LIBRARY_PATH)

热门文章

  1. rar x 解压rar文件,提示permission denied
  2. 安装多个版本号jdk后java -version不改变的问题解决
  3. Java图形界面(GUI)——如何将JTable成功放入面板
  4. setResult详解
  5. 在Android系统中添加宏控制代码【原创】
  6. js 获取现在时间一个月(N天)后的日期
  7. 【转】In ASP.NET using jQuery Uploadify upload attachment
  8. nginx 限制ip/限制访问路径
  9. insert into 语句的三种写法 以及批量插入
  10. vue开发的项目中遇到的警告,报错,配置项目文件等合集(长期更新)