-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathLongestPalindromeSubString.java
More file actions
37 lines (32 loc) · 1 KB
/
LongestPalindromeSubString.java
File metadata and controls
37 lines (32 loc) · 1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
package com.company;
import org.junit.Test;
// 最长回文子串
public class LongestPalindromeSubString {
public boolean isPalindrome(String mString) {
for (int i = 0; i < mString.length(); i++) {
if (mString.charAt(i) != mString.charAt(mString.length() - 1 - i))
return false;
}
return true;
}
public String longestPalindrome(String s) {
int windowSize = s.length();
int end;
int i;
while (windowSize > 0) {
for (i = 0; i + windowSize <= s.length(); i++) {
end = windowSize + i - 1;
if (isPalindrome(s.substring(i, end + 1))) {
return s.substring(i, end + 1);
}
}
windowSize--;
}
return "";
}
@Test
public void test() {
String mString = "babaddtattarrattatddetartrateedredividerb";
System.out.println(longestPalindrome(mString));
}
}