验证回文串
题目
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例 1:
输入: "A man, a plan, a canal: Panama"
输出: true
示例 2:
输入: "race a car"
输出: false
思路
- 笨办法,两次遍历,第一次出去所有非字母和数字字符,第二次前后比较是否相同
代码
- 笨办法
class Solution {
public boolean isPalindrome(String s) {
//忽略大小写,只考虑数字和字母,所有的空格都不算
//第一步,去除所有的空格
//第二步,找到字符串的中间位置向两遍扩展比较
StringBuilder sb = new StringBuilder();
for(int i = 0;i < s.length();i++){
if(s.charAt(i) >= 'a' && s.charAt(i) <= 'z' || (s.charAt(i) >= 'A' && s.charAt(i) <= 'Z') || (s.charAt(i) >= '0' && s.charAt(i) <= '9')){
sb.append(s.charAt(i));
}
}
if(sb.length() == 0){
return true;
}
s = sb.toString().toLowerCase();
for(int i = 0;i < s.length() / 2;i++){
if(s.charAt(i) != s.charAt(s.length()-1-i)){
return false;
}
}
return true;
}
}