HDU-1711-Number Sequence(KMP)(Rabin-Karp)
- Rabin-Karp
Accepted 1711 904MS 5272K 1310 B G++ #include "bits/stdc++.h"
using namespace std;
typedef long long LL;
const int MAXN = 1e6 + ;
const int SEED = 1e9 + ;
int arr[MAXN];
int main() {
int t, n, m, k;
scanf("%d", &t);
while (t--) {
LL p = , s = , head = ;
bool flag = false;
scanf("%d%d", &n, &m);
for (int i = ; i <= n; i++) {
scanf("%d", &arr[i]);
}
// 获取模式串(M数组)的哈希值
for (int i = ; i <= m; i++) {
scanf("%d", &k);
head *= SEED;
p = p * SEED + k;
}
// 获取arr[0]所表示的长度为m的串的哈希值
for (int i = ; i < m; i++) {
/*
比较标准的写法是s = (s * SEED + arr[i]) % MOD;(MOD是一个和SEED互质的数)
这里利用LL的溢出来省略MOD,可以将MOD看成2的64次方
*/
s = s * SEED + arr[i];
}
for (int i = ; i <= n - m + ; i++) {
// 用arr[i - 1]所表示的长度为m的串的哈希值得到arr[i]所表示的长度为m的串的哈希值
s = s * SEED - head * arr[i - ] + arr[i + m - ];
if (s == p) {
flag = true;
printf("%d\n", i);
break;
}
}
if (!flag) {
puts("-1");
}
}
return ;
}Rabin-Karp获取哈希值的形式有点像进制转换,由于计算机内二进制加减是不管符号的所以p和s变成负数也无所谓,用unsigned long long和long long是一样的。但是Rabin-Karp不保证匹配结果绝对正确,因为不同的串哈希值可能一样(long long的范围只有2的64次方,但是本题数组值的范围是[-1000000, 1000000],只要三四位产生的串的数量long long就不够放了)所以如果竞赛中用此法错了,可以尝试改SEED。还不行那就只能换方法了。
- KMP
Accepted 1711 842MS 5360K 802 B G++ #include "bits/stdc++.h"
using namespace std;
const int MAXN = 1e6 + ;
const int MAXM = 1e4 + ;
int s[MAXN], p[MAXM], Next[MAXM] = {-};
int t, n, m;
int kmp() {
int i = , j = -;
// 求模式串的Next
while (i < m) {
if (j == - || p[i] == p[j]) {
Next[++i] = ++j;
} else {
j = Next[j];
}
}
i = , j = ;
while (i < n) {
if (j == - || s[i] == p[j]) {
i++;
if (++j == m) {
// 由于题目题目描述的数组下标从1开始,所以追加1
return i - m + ;
}
} else {
j = Next[j];
}
}
return -;
}
int main() {
scanf("%d", &t);
while (t--) {
scanf("%d%d", &n, &m);
for (int i = ; i < n; i++) {
scanf("%d", &s[i]);
}
for (int i = ; i < m; i++) {
scanf("%d", &p[i]);
}
printf("%d\n", kmp());
}
return ;
}复杂度为O(M + N)
HDU-1711-Number Sequence(KMP)(Rabin-Karp)的更多相关文章
- HDU 1711 Number Sequence(KMP裸题,板子题,有坑点)
Number Sequence Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- hdu 1711 Number Sequence KMP 基础题
Number Sequence Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- HDU 1711 Number Sequence (KMP 入门)
Number Sequence Problem Description Given two sequences of numbers : a[1], a[2], ...... , a[N], and ...
- HDU 1711 - Number Sequence - [KMP模板题]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1711 Time Limit: 10000/5000 MS (Java/Others) Memory L ...
- HDU 1711 Number Sequence KMP
题目地址: http://acm.hdu.edu.cn/showproblem.php?pid=1711 AC代码: #include <iostream> #include <cs ...
- HDU 1711 Number Sequence (字符串匹配,KMP算法)
HDU 1711 Number Sequence (字符串匹配,KMP算法) Description Given two sequences of numbers : a1, a2, ...... , ...
- HDU 1711 Number Sequence(数列)
HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- HDU 1711 Number Sequence 【KMP应用 求成功匹配子串的最小下标】
传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1711 Number Sequence Time Limit: 10000/5000 MS (Java/O ...
- HDU 1711 Number Sequence(KMP)附带KMP的详解
题目代号:HDU 1711 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1711 Number Sequence Time Limit: 10000/ ...
- HDU 1711 Number Sequence (KMP简单题)
Number Sequence Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
随机推荐
- Aras Innovator时间验证
//方法名:bcs_Nexteer_CheckTime //功能描述:开始和结束日期对比 //原作者:joe //创建时间:20141226 //版权所有(C)JOE.FAN //debugger; ...
- 干货 | 调用AI api 实现网页文字朗读
京东云上提供了足够多的人工智能api,并且都使用了http的方式进行了封装,用户可以方便在自己的系统中接入京东云的ai能力.今天就是介绍一下如何编写很少的代码就能使用京东云的语音合成api在网页中实现 ...
- 17.3.12--smtplib模块发送邮件__抄送,安装与下载
1-----在日常编程中,经常会用到处理email,发送,接收,抄送,下载邮件内容等操作,这时候就需要用Python的smtplib模块 smtplib与Email服务器(server)相互通信来传送 ...
- ZJNU 1223 - 素数距离——高级
因为最大可以达到int极限 明显直接筛选不可能完成 所以从其因子入手 因为任何不是素数的数都有除了1与其自身之外的因子 因此,我们筛出2^(31/2)≍46350之内的所有素数,以其作为因子再将题目给 ...
- springboot学习笔记:8. springboot+druid+mysql+mybatis+通用mapper+pagehelper+mybatis-generator+freemarker+layui
前言: 开发环境:IDEA+jdk1.8+windows10 目标:使用springboot整合druid数据源+mysql+mybatis+通用mapper插件+pagehelper插件+mybat ...
- js 选中div中的文本
function selectText(element) { var text = document.getElementById(element); if (document.body.create ...
- 浙江省赛 ZOJ - 4033
题意: 第一行给出T代表有几个测试样例, 第二行给出n代表有几个人, 第三行给出一个由0和1组成的字符串,0代表女生,1代表男生. 并且第i个人有i个宝石. 现在要把这些人分为四组,G1 G2 两组是 ...
- Java常用的公共方法
--获取规字符串中的指定名称的某个字段值 1.public String getValueByName(String params,String name) --用于通过表单选中的复选框获取它的值(j ...
- jdk8下载地址
http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html Java SE Binaries ...
- Microsoft COCO 数据集
本篇博客主要以介绍MS COCO数据集为目标,分为3个部分:COCO介绍,数据集分类和COCO展示. 本人主要下载了其2014年版本的数据,一共有20G左右的图片和500M左右的标签文件.标签文件标记 ...