zoukankan      html  css  js  c++  java
  • LeetCode 5. Longest Palindromic Substring

    Given a string s, find the longest palindromic substring in s. You may assume that the maximum length of s is 1000.

    Example 1:
    Input: "babad"
    Output: "bab"
    Note: "aba" is also a valid answer.

    Example 2:
    Input: "cbbd"
    Output: "bb"

    class Solution {
    public:
        string longestPalindrome(string s) {
        if (s.empty()) return "";
        if (s.size() == 1) return s;
        int min_start = 0, max_len = 1;
        for (int i = 0; i < s.size();) {
          if (s.size() - i <= max_len/2) break;
          int j = i, k = i;
          while (k < s.size()-1 && s[k+1] == s[k]) ++k; // Skip duplicate characters.
          i = k+1;
          while (k < s.size()-1 && j > 0 && s[k + 1] == s[j - 1]) { ++k; --j; } // Expand.
          int new_len = k - j + 1;
          if (new_len > max_len) { min_start = j; max_len = new_len; }
        }
        return s.substr(min_start, max_len);
    }
    };
    /*
    string longestPalindrome(string s) {
            if(s.size()==0) return s;
            int res = 1;
            string ans = s.substr(0, 1);
            vector<vector<int>> dp(s.size(), vector<int>(s.size(), 0));
            for(int i=0; i<s.size(); i++){
                dp[i][i] = 1;
                if( i < s.size()-1 && s[i] == s[i+1]){
                    dp[i][i+1] = 1;
                    ans = s.substr(i, 2);
                }       
            }
            for(int len = 3; len <= s.size(); len++)
                for(int i=0; i<= s.size()-len; i++)
                    if(dp[i+1][i+len-2]==1 && s[i]==s[i+len-1]){
                        dp[i][i+len-1] = 1;
                        ans = s.substr(i, len);
                    }
            return ans;
        }
    */
    
  • 相关阅读:
    P2519 [HAOI2011]problem a
    P1084 疫情控制
    P1941 飞扬的小鸟
    NOIP填坑计划
    P2831 愤怒的小鸟
    AGC 16 D
    P3960 列队
    Python3爬虫相关软件,库的安装
    软件理论基础—— 第一章命题逻辑系统L
    软件理论基础——导论
  • 原文地址:https://www.cnblogs.com/A-Little-Nut/p/10041074.html
Copyright © 2011-2022 走看看