-
Notifications
You must be signed in to change notification settings - Fork 0
/
P125_IsPalindrome.java
52 lines (47 loc) · 1.35 KB
/
P125_IsPalindrome.java
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package leetCode;
/**
* @className P125_IsPalindrome.java
* @author AT
* @version Create Time:2019年7月18日 上午11:10:51
* @question leetcode.p125:验证回文串
* @describe 给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
* @describe 本题中,将空字符串定义为有效的回文串。
*/
public class P125_IsPalindrome {
public static boolean isPalindrome(String s) {
// 当一个字符和一个整数相加时,计算时使用的是字符的统一码。
// (int)('10'-'0');返回10
if (s.length() == 0) {
return true;
}
int l = 0, r = s.length() - 1;
char cl = ' ', cr = ' ';
while (l < r) {
while (l < r && !Character.isLetterOrDigit(s.charAt(l)))
l++;
while (l < r && !Character.isLetterOrDigit(s.charAt(r)))
r--;
cl = s.charAt(l++);
cr = s.charAt(r--);
if (Character.isDigit(cl) || Character.isDigit(cr)) {
if (cl != cr) {
return false;
}
continue;
}
cl = Character.toLowerCase(cl);
cr = Character.toLowerCase(cr);
if (cl != cr) {
return false;
}
}
return true;
}
public static void main(String[] args) {
// TODO Auto-generated method stub
String s = " A man, a plan, a ccanal: Panama";
System.out.println(isPalindrome(s));
char c = ' ';
System.out.println(Character.digit(c, 10));
}
}