• hihoCoder 1015 KMP算法(kmp)


    #1015 : KMP算法

    时间限制:1000ms
    单点时限:1000ms
    内存限制:256MB

    描写叙述

    小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣。他们约定好互相帮助,在编程的学习道路上一同前进。

    这一天。他们遇到了一仅仅河蟹,于是河蟹就向小Hi和小Ho提出了那个经典的问题:“小Hi和小Ho,你们能不可以推断一段文字(原串)里面是不是存在那么一些……特殊……的文字(模式串)?

    小Hi和小Ho细致思考了一下,认为仅仅能想到非常easy的做法,可是又认为既然河蟹先生这么说了,就肯定不会这么easy的让他们回答了。于是他们仅仅能说道:“抱歉,河蟹先生,我们仅仅能想到时间复杂度为(文本长度 * 特殊文字总长度)的方法,即对于每一个模式串分开推断,然后依次枚举起始位置并检查是否可以匹配,可是这不是您想要的方法是吧?”

    河蟹点了点头,说道:”看来你们的水平还有待提高。这样吧。假设我说仅仅有一个特殊文字,你能不能做到呢?“

    小Ho这时候还有点晕晕乎乎的,可是小Hi非常快开口道:”我知道!这就是一个非常经典的模式匹配问题!

    能够使用KMP算法进行求解。“

    河蟹惬意的点了点头,对小Hi说道:”既然你知道就好办了,你去把小Ho教会。下周我有重要的任务交给你们。“

    ”保证完毕任务。”小Hi点头道。

    提示一:KMP的思路

    提示二:NEXT数组的使用

    提示三:怎样求解NEXT数组

    输入

    第一行一个整数N。表示測试数据组数。

    接下来的N*2行,每两行表示一个測试数据。

    在每个測试数据中。第一行为模式串,由不超过10^4个大写字母组成。第二行为原串,由不超过10^6个大写字母组成。

    当中N<=20

    输出

    对于每个測试数据。依照它们在输入中出现的顺序输出一行Ans。表示模式串在原串中出现的次数。

    例子输入
    5
    HA
    HAHAHA
    WQN
    WQN
    ADA
    ADADADA
    BABABB
    BABABABABABABABABB
    DAD
    ADDAADAADDAAADAAD
    例子输出
    3
    1
    3
    1
    

    0

    没什么好说的,模板题

    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    #include <iostream>
    #include <string>
    using namespace std;
    int f[ 15000];
    void getfill(string s)
    {
        memset(f,0,sizeof(f));  //依据其前一个字母得到
        for(int i=1;i<s.size();i++)
        {
            int j=f[i];
            while(j && s[i]!=s[j])
                j=f[j];
            f[i+1]=(s[i]==s[j])?j+1:0;
        }
    }
    int find(string a,string s)
    {
        int ans=0;
        getfill(s);int j=0;
        for(int i=0;i<a.size();i++)
        {
            while(j && a[i]!=s[j])
                j=f[j];
            if(a[i]==s[j])
                j++;
            if(j==s.size()){
                ans++;
            }
        }
        return ans;
    }
    int main()
    {
        string s,a;
        int T;
        scanf("%d",&T);
        while(T--)
        {
            getchar();
            cin>>s>>a;
            int ans=find(a,s);
            printf("%d
    ",ans);
        }
        return 0;
    }
    


  • 相关阅读:
    Cannot find module 'webpack'
    Failed to read auto-increment value from storage engine
    laravel框架查看执行过的sql语句
    windows与虚拟机共享文件夹设置
    csv导出文件中有html
    特定中文字符串正则匹配
    运动跟踪等算法的解释
    自控力这本书的读后感
    提取肤色信息原理及操作——opencv
    那些年我们排过的序之希尔排序
  • 原文地址:https://www.cnblogs.com/claireyuancy/p/7358919.html
Copyright © 2020-2023  润新知