码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode 05 最长回文字串

时间:2020-10-22 23:03:29      阅读:17      评论:0      收藏:0      [点我收藏+]

标签:java代码   起点   png   https   while   ima   pre   一个   --   

LeetCode05 最长回文字串

题目描述

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

样例

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

算法分析

技术图片

回文串:我们可以以i为中心为起点,分别往两边走,对比即可,停下来的时候就是最长的回文字串

技术图片

时间复杂度

\(O(n^2)\)

Java代码

class Solution {


    public String longestPalindrome(String s) {

        String res = "";
        for(int i = 0; i<s.length(); i++){
            //奇数情况
            int l = i - 1;
            int r = i + 1;
            while(l >= 0 && r < s.length() && s.charAt(l) == s.charAt(r)){
                r ++;
                l --;
            }
			
            // r-1 - (l+1) + 1 = r - l - 1
            if(res.length()<r-l-1) res=s.substring(l+1,r);
			
            //偶数情况
            l = i;
            r = i + 1;
            while(l >= 0 && r < s.length() && s.charAt(l) == s.charAt(r)){
                r ++;
                l --;
            }

            if(res.length()<r-l-1) res=s.substring(l+1,r);

        }

        return res;

    }
}

LeetCode 05 最长回文字串

标签:java代码   起点   png   https   while   ima   pre   一个   --   

原文地址:https://www.cnblogs.com/vccyb/p/13859480.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!