HDOJ-1711(KMPアルゴリズム)

数列

HDOJ-1711

1.ここで使用されるアルゴリズムは、PIは、接頭辞配列の配列である、KMPアルゴリズムです。
技術を使用すること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;
}

おすすめ

転載: www.cnblogs.com/GarrettWale/p/11325195.html