LeetCode之最长回文子串

1.题目链接

5. 最长回文子串 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/longest-palindromic-substring/description/

2.题目解析

对于这道题目我们可以使用动态规划的思路来求解,具体思路是,对于一个长度大于2的子串,如果它是回文串的话,那么将它首尾的两个字母去除之后,它仍然是个回文串。例如对于“ababa”,将首尾字符串去掉,剩下的还是回文串,那么我们就可以列出下面状态转移方程:

当子串长度大于2时

f[i][j] = f[i+1][j-1]\wedge s[i]==s[j]

当子串长度等于2时

f[i][j]=(s[i]==s[j])

3.代码如下:

class Solution {
public:
    string longestPalindrome(string s) {
        int n=s.size();

        bool f[n][n];

        memset(f,false,sizeof f);

        int maxi=0;

        string res;

        for(int l=1;l<=n;l++)
        {
            for(int i=0;i+l-1<n;i++)
            {
                int j=i+l-1;
                if(s[i]==s[j])
                {
                    if(j-i<3)
                    {
                        f[i][j]=true;
                    }
                    else if(f[i+1][j-1])
                    f[i][j]=true;

                    if(f[i][j]&&l>=maxi)
                    {
                        maxi=l;
                        res=s.substr(i,l);
                    }
                }
            }
        }
    
        return res;
    }
};

猜你喜欢

转载自blog.csdn.net/m0_74732859/article/details/140362817