HDOJ-1711(KMP算法)

本文介绍了一种利用KMP算法进行序列匹配的方法,特别关注于如何处理大规模数据集,通过添加特殊字符和使用快速输入输出语句来优化算法性能。文中详细解释了KMP算法的工作原理,包括pi数组的计算过程,并提供了一个具体的实现代码示例。
摘要由CSDN通过智能技术生成

Number Sequence

HDOJ-1711

1.这里使用的算法是KMP算法,pi数组就是前缀数组。
2.代码中使用到了一个技巧就是用c数组看成是复合字符串,里面加一个特殊整数位-1000006,因为它永远不会出现在数组中。
3.额外需要注意的就是,需要加快速输入输出语句,因为涉及到的数据量有点大,所以会超时,当然,也可以选用scanf也可以。

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int n,m;
int a[1000006],b[10004];
int pi[1000006];
int c[1010010];
void Pi(int len){
    memset(pi,0,sizeof(pi));
    int n=len;
    pi[0]=0;
    for(int i=1;i<n;i++){
        int j=pi[i-1];
        while(j>0&&c[i]!=c[j]){
            j=pi[j-1];
        }
        if(c[i]==c[j])
            j++;
        pi[i]=j;
    }
}
int main(){
    ios::sync_with_stdio(false);//不加这两条语句会超时
    cin.tie(0);
    int t;
    cin>>t;
    while(t--){
        cin>>n>>m;
        int a1,b1;
        for(int i=0;i<n;i++){
           cin>>a[i];
           c[i]=a[i];
        }
        for(int j=0;j<m;j++){
            cin>>b[j];
            c[j]=b[j];
        }
        c[m]=-1000006;
        for(int i=m+1;i<n+m+1;i++){
           c[i]=a[i-m-1];
        }
        Pi(m+n+1);
        int ans=-1;
        for(int i=m+1;i<n+1+m;i++){
            //cout<<pi[i]<<endl;
            if(pi[i]==m){
                ans=i-(m-1)-(m+1);
                ans++;
                break;
            }
        }
        cout<<ans<<endl;
    }
    return 0;
}

转载于:https://www.cnblogs.com/GarrettWale/p/11325195.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值