• 腾讯//最长回文子串


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

    示例 1:

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

    示例 2:

    输入: "cbbd"
    输出: "bb"
    class Solution {
    public:
        string longestPalindrome(string s) {
            if(s.size()<2) return s;
            int n = s.size(),maxLen = 0, start = 0;
            for(int i = 0; i < n - 1; i++){
                searchPalindrome(s,i,i,start,maxLen);
                searchPalindrome(s,i,i+1,start,maxLen);
            }
            return s.substr(start, maxLen);
        }
        void searchPalindrome(string s, int left, int right, int &start, int &maxLen){
            while(left>=0&&right<s.size()&&s[left] == s[right]){
                --left;
                ++right;
            }
            if(maxLen < right - left - 1){
                start = left + 1;
                maxLen = right - left - 1;
            }
        }
    };
    class Solution {
    public:
        string longestPalindrome(string s) {
            if(s.size() < 2)
                return s;
            int n = s.size(),maxLen = 0, start = 0;
            for(int i = 0; i < n;){
                if(n - i <= maxLen/2) break;
                int left = i, right = i;
                while(right < n - 1 && s[right+1] == s[right]) ++right;
                i = right + 1;
                while(right < n - 1 && left > 0 && s[right+1] == s[left-1]){
                    ++right;
                    --left;
                }
                if(maxLen < right - left + 1){
                    maxLen = right - left + 1;
                    start = left;
                }
            }
            return s.substr(start, maxLen);
        }
    };
    class Solution {
    public:
        string longestPalindrome(string s) {
            if(s.empty()) return "";
            int dp[s.size()][s.size()] = {0}, left = 0, right = 0, len = 0;
            for(int i = 0; i < s.size(); i++){
                for(int j = 0; j < i; j++){
                    dp[j][i] = (s[i]==s[j]&&(i-j<2||dp[j+1][i-1]));
                    if(dp[j][i]&&len<i-j+1){
                        len = i-j+1;
                        left = j;
                        right = i;
                    }
                }
                dp[i][i] = 1;
            }
            return s.substr(left,right-left+1);
        }
    };
    class Solution {
    public:
        string longestPalindrome(string s) {
            string t = "$#";
            for(int i = 0; i < s.size(); i++){
                t += s[i];
                t += '#';
            }
            int p[t.size()] = {0}, id = 0, mx = 0, resId = 0, resMx = 0;
            for(int i = 0; i < t.size(); i++){
                p[i] = mx > i ? min(p[2*id-i], mx-i) : 1;
                while(t[i + p[i]] == t[i - p[i]]) ++p[i];
                if(mx < i+p[i]){
                    mx = i + p[i];
                    id = i;
                }
                if(resMx < p[i]){
                    resMx = p[i];
                    resId = i;
                }
            }
            return s.substr((resId - resMx) / 2, resMx-1);
        }
    };
  • 相关阅读:
    xx系统需求分析01—用户权限管理(一)
    软件工程第五周总结
    Hbase的常用shell命令+Java操作
    软件需求阅读笔记02
    MyBatis学习总结03-动态SQL
    MyBatis学习总结02
    MyBatis学习总结01
    软件工程第四周总结
    软件需求阅读笔记01
    MapReduce案例-流量统计
  • 原文地址:https://www.cnblogs.com/strawqqhat/p/10602510.html
Copyright © 2020-2023  润新知