Longest Palindromic Substring--求字符串最长回文子串 - Leetcode

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

Example:

Input: "babad"

Output: "bab"

Note: "aba" is also a valid answer.

Example:

Input: "cbbd"

Output: "bb"

所谓回文结构即:

a-b-c-b-a   true

a-b-c-a-a   false 

基本的想法是遍历所有的回文的支点范围从第一个字符的字符串的字符串的最后一个字符的。使用StringBuilder来降低空间复杂度。

(考虑偶数与奇数长度的情况--我们也可以在每个字符中间插入特殊字符如# 来保证整个字符串回文子串始终为奇数情况。如#a#b#b#a#)

public class Solution {
    
    public  String longestPalindrome(String s) {
		StringBuilder longest = new StringBuilder("");
	    if (s.length() <= 1) return s;
	    
	    StringBuilder str = new StringBuilder();
	    
	    for (int i = 0; i < s.length(); i++) {
	    	str.append("#");
	    	str.append(s.charAt(i));
	    }
	    str.append("#");
	    s = str.toString();
	    
	    for (int i = 0; i < s.length(); i++) {
	        expand(str.toString(), longest, i, i); 
	    }
	    
	    s = longest.toString().replaceAll("#", "");
	    return s;
	}
	private static void expand(String s, StringBuilder longest, int i, int j) {
		
	    while (i >= 0 && j < s.length()) {
	        if (s.charAt(i) == s.charAt(j)) {
	            if (j - i + 1 > longest.length()) {
	                longest.delete(0, longest.length());
	                longest.append(s.substring(i, j + 1));
	            }
	            i--;
	            j++;
	        }
	        else
	            break;
	    }
	}

}






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值