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;
    }
posted @ 2012-06-09 10:09  百分百好牛  阅读(2325)  评论(2编辑  收藏  举报