zoukankan      html  css  js  c++  java
  • L2-008 最长对称子串 (25 分)

    L2-008 最长对称子串 (25 分)

    对给定的字符串,本题要求你输出最长对称子串的长度。例如,给定 Is PAT&TAP symmetric?,最长对称子串为 s PAT&TAP s,于是你应该输出 (11)

    输入格式:

    输入在一行中给出长度不超过 (1000) 的非空字符串。

    输出格式:

    在一行中输出最长对称子串的长度。

    输入样例:

    Is PAT&TAP symmetric?
    

    输出样例:

    11
    

    参考代码:

    #include<bits/stdc++.h>
    using namespace std;
    #define maxn 1005
    int pos[maxn<<1];
    string s,t;
    inline int pre()
    {
        t="$#";
        for(int i=0;s[i]!='';i++)
        {
            t+=s[i];
            t+='#';
        }
        return 2*s.length()+2;
    }
    inline int Manacher()
    {
        int len=pre(),mid=1,r=0,ans=1;
        for(int i=1;i<len;i++)
        {
            if(i<r)pos[i]=min(r-i,pos[mid*2-i]);
            else pos[i]=1;
            while(t[i-pos[i]]==t[i+pos[i]])pos[i]++;
            if(r<i+pos[i])
            {
                mid=i;
                r=i+pos[i];
            }
            ans=max(ans,pos[i]-1);
        }
        return ans;
    }
    int main()
    {
        getline(cin,s);
        cout<<Manacher()<<endl;
        return 0;
    }
    
  • 相关阅读:
    23.课程应用接口
    22.课程页面设计
    21.手机接口
    20.云通讯
    19.JWT
    18.权限认证
    解决github下载慢的终极方法
    vs code 配置c/c++环境
    Python 字符编码处理总结
    Python编码
  • 原文地址:https://www.cnblogs.com/LengYun/p/14691149.html
Copyright © 2011-2022 走看看