string s;
int Next[MAX];
int len;
void get_next()
{
    int i=0,j=-1;
    Next[i]=j;//初始化,next[0]=-1;-1表示没有前缀等于后缀。
    for(i=1;i<len;i++)
    {
        while(j>-1&&s[j+1]!=s[i])
            j=Next[j];//回溯
        if(s[j+1]==s[i]) j++;//表示这个字符匹配了
        Next[i]=j;
    }
}

 

相关文章:

  • 2021-08-22
  • 2021-09-27
  • 2022-12-23
  • 2021-10-08
  • 2021-11-04
  • 2022-12-23
  • 2022-12-23
  • 2021-08-18
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-09-06
相关资源
相似解决方案