125-验证回文串

验证回文串

题目

给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。

说明:本题中,我们将空字符串定义为有效的回文串。

示例 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;
    }
}

你可能感兴趣的:(125-验证回文串)