zoukankan      html  css  js  c++  java
  • 【kmp算法】hdu4763 Theme Section

    kmp中next数组的含义是:next[i]表示对于s[0]~s[i-1]这个前缀而言,最大相等的前后缀的长度是多少。规定next[0]=-1。

    迭代for(int i=next[i];i!=-1;i=next[i]) 就可以得到某个前缀所有长度相等的前后缀的长度。

    这题你就暴力枚举整个字符串的所有相等的前后缀,然后暴力判中间的部分是否存在即可。当然使用next数组会很简便。

    #include<cstdio>
    #include<cstring>
    using namespace std;
    int next[1000100],T,n;
    char s[1000100];
    void GetFail(char P[],int next[])//next[i]表示s[0]~s[i-1]的前缀中,最大相等的前后缀的长度是多少 
    {
        next[0]=-1;
        int len=strlen(P);
        for(int i=0;i<len;i++)
          {
            int j=next[i];
            while(j>=0&&P[i]!=P[j])
    		  j=next[j];
            if(j!=-1 && P[i]==P[j])
    		  next[i+1]=j+1;
            else next[i+1]=0;
          }
        for(int i=0;i<len;++i)//左移一位形成最大长度表 
          next[i]=next[i+1];
    }
    int main()
    {
    //	freopen("c.in","r",stdin);
    	scanf("%d",&T);
    	for(;T;--T)
    	  {
    	  	scanf("%s",s);
    	  	n=strlen(s);
    	  	GetFail(s,next);
    	  	int E=next[n-1];
    	  	while(E)
    	  	  {
    	  	  	int k=n-E-1;
    	  	  	while(next[k]<E && k>=2*E-1)
    	  	  	  --k;
    	  	  	if(k>=2*E-1)
    	  	  	  {
    	  	  	  	printf("%d
    ",E);
    	  	  	  	goto OUT;
    	  	  	  }
    	  	  	E=next[E-1];
    	  	  }
    	  	puts("0");
    	  	OUT:;
    	  }
    	return 0;
    }
  • 相关阅读:
    JavaScript 操作CSS
    源码搭建LAMP服务器
    Modified 2 color sort
    python的网络库
    找出有序整数数组中下标与值相同的所有元素
    sql 查看Oralce 数据库连接状态
    oracle 快闪 sql
    Sql server dblink
    昆山桶装水/免费送货上门/
    C# Tostring() 格式大全 [转]
  • 原文地址:https://www.cnblogs.com/autsky-jadek/p/6412094.html
Copyright © 2011-2022 走看看