KMP(http://acm.hdu.edu.cn/showproblem.php?pid=1711)
http://acm.hdu.edu.cn/showproblem.php?pid=1711
#include<stdio.h>
#include<math.h>
#include<string.h>
#include<stdlib.h>
int a[], b[], next[];
int n, m; void GetNext(int b[])//获得next数组
{
int k = -, j = ;
next[] = -;
while(j < m)
{
if(k == - || b[j] == b[k])//b[k]表示前缀b[j]表示后缀
{
j++;
k++;
if(b[j] != b[k])
next[j] = k;
else
next[j] = next[k];
}
else
k = next[k];
}
} int KMP(int a[], int b[])
{
int i = , j = ;
while(i < n && j < m)
{
if(j == - || a[i] == b[j])//j == -1或当前字符匹配成功,则i++,j++
{
i++;
j++;
}
else//j != -1 且当前字符匹配成功,b字符串向后移动j-next[j]位
j = next[j];
}
if(j == m)
return i - j + ;
return -;
}
int main()
{
int t, i;
scanf("%d", &t);
while(t--)
{
scanf("%d%d", &n, &m);
for(i = ; i < n ; i++)
scanf("%d", &a[i]);
for(i = ; i < m ; i++)
scanf("%d", &b[i]);
GetNext(b);
printf("%d\n", KMP(a, b));
}
return ;
}
KMP(http://acm.hdu.edu.cn/showproblem.php?pid=1711)的更多相关文章
- KMP应用http://acm.hdu.edu.cn/showproblem.php?pid=2594
		
riemann与marjorie拼接后riemannmarjorie前缀与后缀公共部分为 rie 长度为 3(即next[l] = next[14]的值,l为拼接后的长度)但:aaaa与aa拼接后aa ...
 - HDU 4911 http://acm.hdu.edu.cn/showproblem.php?pid=4911(线段树求逆序对)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4911 解题报告: 给出一个长度为n的序列,然后给出一个k,要你求最多做k次相邻的数字交换后,逆序数最少 ...
 - HDU-4632                     http://acm.hdu.edu.cn/showproblem.php?pid=4632
		
http://acm.hdu.edu.cn/showproblem.php?pid=4632 题意: 一个字符串,有多少个subsequence是回文串. 别人的题解: 用dp[i][j]表示这一段里 ...
 - 待补 http://acm.hdu.edu.cn/showproblem.php?pid=6602
		
http://acm.hdu.edu.cn/showproblem.php?pid=6602 终于能够看懂的题解: https://blog.csdn.net/qq_40871466/article/ ...
 - 饭卡 (背包01   一维数组)  http://acm.hdu.edu.cn/showproblem.php?pid=2546
		
/* 从一组数据中选出n个数,使这n个数的和最接近一个值x, 背包问题, 从一系列菜中,从最贵的菜(MAX)之外中选出几个菜,使菜的总价格sum最接近money-5:money-sum-MAX; 钱数 ...
 - HDU-1257 导弹拦截系统 http://acm.hdu.edu.cn/showproblem.php?pid=1257
		
Problem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高 ...
 - HDU1973 http://acm.hdu.edu.cn/showproblem.php?pid=1973
		
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<queue> #inc ...
 - Problem - 1062  http://acm.hdu.edu.cn/showproblem.php?pid=1062
		
对输入字符串的字符的倒置,在这个程序中,我觉得自己最大的问题是怎么识别一个字符,代码中有t个字符串,每个字符串,每个字符串中有若干个单词,单词之间有空格,所以对于下列的正确答案,我的疑惑是当我键盘输入 ...
 - http://acm.hdu.edu.cn/showproblem.php?pid=2579
		
#include<stdio.h> #include<string.h> #include<queue> #define N 110 int m, n, k, x1 ...
 
随机推荐
- 线程——QQ邮件发送
			
一.造一个QQ邮件发送的窗体 二.开始编写关于邮件发送的代码,以及当点发送按钮的时候,给发送按钮单独造了一个新的线程.这样如果发送的附件太多的话,如果不给发送按钮造新的线程,便会卡住,但是如果给发送按 ...
 - 用Access作为后台数据库支撑,书写一个C#写入记录的案例
			
要想操作一个数据库,不论是那种操作,首先要做的肯定是打开数据库. 下面我们以ACCESS数据库来做例子说明如何打开一个数据库连接! 在这里我们需要用到的是: System.Data.OleDb.O ...
 - Uva 10382 (区间覆盖) Watering Grass
			
和 Uva 10020几乎是一样的,不过这里要把圆形区域转化为能够覆盖的长条形区域(一个小小的勾股定理) 学习一下别人的代码,练习使用STL的vector容器 这里有个小技巧,用一个微小量EPS来弥补 ...
 - Struts2 的 helloworld
			
配置步骤: 1.在你的strut2目录下找到例子项目,把它的 lib 下的jar拷贝到你的项目.例如我的:struts-2.3.24\apps\struts2-blank 2.struts-2.3.2 ...
 - Eclipse 打开编辑文件所在文件夹方法
			
一个便捷的方法在eclipse的菜单中,依次点击Run->External Tools-> External Tools configurations添加一个新的工具 OpenContai ...
 - 2016第20周四java基础概念
			
简单的说JDK=JRE+Java编译器.调试器.工具类库等:JRE=JVM(类似于jre目录下的bin)+必要运行的类库(类似于jre目录下的lib) JVM:Java Virtual Mechina ...
 - 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:2.搭建环境-2.5. 配置网络
			
2.5. 配置网络 2.5.1. 配置网络 Oracle Rac数据库涉及到公用网络和私有网络,因此要做网络划分和IP地址规划,下表列出了要安装的RAC数据库对应的IP地址.主机名以及网络连接类型: ...
 - C# Math.Round中国式的四舍五入法
			
double dou = 1.255; //这种是错误的 double dou_result = Math.Round(dou, 2); //结果: 1.25 dou_result = Math.Ro ...
 - Javascript中的Keycode值列表
			
关于如何得到一个键在Javascript中的Keycode值,可以参考: <body onkeypress=alert(event.keyCode)>请按任意键,你将得到该键的键值! ke ...
 - oracle sql语句跟踪
			
select b.SQL_TEXT,b.FIRST_LOAD_TIME,b.SQL_FULLTEXT from v$sqlarea b order by b.FIRST_LOAD_TIM ...