• 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)的更多相关文章

  1. HDU 1711 Number Sequence(KMP裸题,板子题,有坑点)

    Number Sequence Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  2. hdu 1711 Number Sequence KMP 基础题

    Number Sequence Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  3. HDU 1711 Number Sequence (KMP 入门)

    Number Sequence Problem Description Given two sequences of numbers : a[1], a[2], ...... , a[N], and ...

  4. HDU 1711 - Number Sequence - [KMP模板题]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1711 Time Limit: 10000/5000 MS (Java/Others) Memory L ...

  5. HDU 1711 Number Sequence KMP

    题目地址: http://acm.hdu.edu.cn/showproblem.php?pid=1711 AC代码: #include <iostream> #include <cs ...

  6. HDU 1711 Number Sequence (字符串匹配,KMP算法)

    HDU 1711 Number Sequence (字符串匹配,KMP算法) Description Given two sequences of numbers : a1, a2, ...... , ...

  7. HDU 1711 Number Sequence(数列)

    HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...

  8. HDU 1711 Number Sequence 【KMP应用 求成功匹配子串的最小下标】

    传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1711 Number Sequence Time Limit: 10000/5000 MS (Java/O ...

  9. HDU 1711 Number Sequence(KMP)附带KMP的详解

    题目代号:HDU 1711 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1711 Number Sequence Time Limit: 10000/ ...

  10. HDU 1711 Number Sequence (KMP简单题)

    Number Sequence Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

随机推荐

  1. 提示Asp.net4.5未在web服务器上注册

    在用vs2012代开项目时, 每回都显示Asp.net4.5未在web服务器上注册,最后是由于没有下载一个补丁的原因,只需要下载安装补丁 VS11-KB3002339.exe ,下载地址:https: ...

  2. SQL 一个【OR】属性给你带来了怎样的麻烦

    关于 数据库  or   的用法,就不说了     讲讲OR对数据库性能有多大的杀伤力,以后线上的项目如果是数据量很大的表,一定不要用OR来查询 今天在工作的时候,同事遇到了SQL优化的问题,让我帮忙 ...

  3. [Algo] 117. Array Deduplication III

    Given a sorted integer array, remove duplicate elements. For each group of elements with the same va ...

  4. 2.redis-help使用,基本命令

    redis 帮助 > help redis-cli Type: "help @<group>" to get a list of commands in < ...

  5. mybatis的XML配置文件中,typeHandler、jdbcType、javaType的使用

    1.前言 typeHandler.jdbcType.javaType都是用来处理java数据类型和jdbc数据库数据类型的转换问题,但在xml的不同位置使用需要注意引号使用问题. 2.在xml的不同位 ...

  6. Fractal Dimension|Relative Complexity|CG含量|重复序列|

    生物信息学-序列拼接方法 物理学方法 Fractal Dimension of Exon and Intron Sequences --------------CGCGGCGTGTGTTATA --- ...

  7. 洛谷 P2278 [HNOI2003]操作系统

    题目传送门 解题思路: 一道没啥思维含量的模拟题,但是个人感觉代码实现不简单,可能是我太弱了,花了我6个小时,3次重写. AC代码: #include<iostream> #include ...

  8. dubbo的重试原则

    验证思路.使用超时来验证重试次数 XML 注解

  9. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis)【第七天】(redis缓存)

    https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ...

  10. D. New Year and Conference(区间交,线段树)

    题:https://codeforces.com/contest/1284/problem/D 题意:给定n个1对的时间断,我是这么理解的,甲去参加a时间段的讲座,乙去参加b时间段的讲座,然后若这n对 ...