5.最长回文数

2018-10-11  本文已影响0人  HITZGD

题目
给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为1000。

示例 1:
输入: "babad"
输出: "bab"
注意: "aba"也是一个有效答案。

示例 2:****
输入: "cbbd"
输出: "bb"

思路:
1.(未考虑形如abba这种的回文情况)构造递归函数,从当前位向两端搜索

#include <string>
using namespace std;
class Solution {
private:
    int maxLen, loca;
public:
    string longestPalindrome(string s) {
        if (s.size() < 2) return s;
        for(int i = 0; i < s.size() - 1; i++)
        {
            findMax(s, i, i);
        }
        return s.substr(loca, loca + maxLen);
    }
private:
    void findMax(string s, int left, int right)
    {
        while (left >= 0 && right < s.size() && s.at(left) == s.at(right))
        {
            left--;
            right++;
        }
        if (maxLen < right - left - 1)
        {
            loca = left + 1;
            maxLen = right - left - 1;
        }
    }
};
上一篇下一篇

猜你喜欢

热点阅读