Problem statement: Given a string s, find the longest palindromic substring in s. You may assume that the maximum length of s is 1000.
- import java.io.IOException;
- public class LongestSubstringPalindrome
- {
- public static void main(String[] args) throws IOException
- {
- // String word = "abbcbba";
- String str = "abbagoodteacher";
- System.out.println(longestPalindrome(str));
- }
- public static String longestPalindrome(String s)
- {
- int length = s.length();
- if (s == null || length < 2)
- {
- return s;
- }
- boolean isPalindrome[][] = new boolean[length][length];
- int left = 0;
- int right = 0;
- for (int j = 1; j < length; j++)
- {
- for (int i = 0; i < j; i++)
- {
- boolean isInnerWordPalindrome = isPalindrome[i + 1][j - 1] || j - i <= 2;
- if (s.charAt(i) == s.charAt(j) && isInnerWordPalindrome)
- {
- isPalindrome[i][j] = true;
- if (j - i > right - left)
- {
- left = i;
- right = j;
- }
- }
- }
- }
- return s.substring(left, right + 1);
- }
- }
Output: abba
No comments:
Post a Comment