zoukankan      html  css  js  c++  java
  • Given a string S, find the longest palindromic substring in S.

    题义很明细:求一个字符串S中的最长回文!

    基本想法:

    for-loop i从0 – (n-1)遍历该字符串,从S[i] 或者 S[i+1]开始,向字符串S的两侧展开,判断是不是回文。如果是,再和当前的最长回文比较,如果更长,则替换当前最长的回文。

    代码如下:

        // 从c1, c2开始 向两侧展开,找到最长的palindrome
        // e.g. 如果已经知道 "aba"是字符串"cabac"的一个字串,palindrome,
        //      则向两侧展开时,"c" == "c", 即 s[l] == s[r],所以能够继续得到更长的palindrome
        string expandAroundCenter(string s, int c1, int c2) 
        {
          int l = c1, r = c2;
          int n = s.length();
          while (l >= 0 && r <= n-1 && s[l] == s[r]) {  // 从c1/l, c2/r开始,向当前位置两侧移动指针
            l--;
            r++;
          }
          return s.substr(l+1, r-l-1);
        }
        // 从每个单独的字符s[i]和(s[i], s[i+1])开始展开,求两侧的最长palindrome
        string longestPalindromeSimple(string s) 
        {
          int n = s.length();
          if (n == 0) return "";
    
          string longest = s.substr(0, 1);  // a single char itself is a palindrome
          for (int i = 0; i < n-1; i++) {
            string p1 = expandAroundCenter(s, i, i);    // assume the palindrome num is odd
            if (p1.length() > longest.length())
              longest = p1;
     
            string p2 = expandAroundCenter(s, i, i+1);  // assume the palindrome num is even
            if (p2.length() > longest.length())
              longest = p2;
          }
          return longest;
        }
  • 相关阅读:
    记录log中的16进制和ASCII码字符输出
    有效的沟通技巧
    时间的真谛
    目标设定与时间管理
    第四代时间管理
    什么是高效沟通
    error LNK1104: cannot open file 错误解决方案
    js压缩工具1.0界面绘制
    时间管理的定义与目的
    JArgs命令行选项解析>Java套件
  • 原文地址:https://www.cnblogs.com/yayagamer/p/2542876.html
Copyright © 2011-2022 走看看