leetcode 5:最长回文子串

std::string longestPalindrome(std::string s){
    if(s.size()==0)return "";
    if(s.size()==1)return s;
    int max=0;
    int start=0;
    for(int i=0;i<s.size()-1;i++)
    {
        int s1=i;
        int t1=s.size()-1;
        int t=s.size()-1;
        while(s1<t)
        {
            if(s[s1]!=s[t]){
                s1=i;
                t1--;
                t=t1;
            }
            else if(s[s1]==s[t]){
                s1++;
                t--;
            }
        }
        if(t1-i+1>max)
        {
            start=i;
            max=t1-i+1;
        }
    }
    return s.substr(start,max);
}

猜你喜欢

转载自blog.csdn.net/u013263891/article/details/83242136