美文网首页
leetcode125:验证回文字符串

leetcode125:验证回文字符串

作者: 杨柳滔滔 | 来源:发表于2019-07-24 17:36 被阅读0次

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

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

    示例 1:

     输入: "A man, a plan, a canal: Panama"
     输出: true
    

    示例 2:

    输入: "race a car"
    输出: false
    

    思路

    • 反正忽略大小写 ,先都转出小写或者大写
    • 过略标点符号
    • 设置双指针遍历,一个在头,一个在尾,看是否一样

    代码

    class Solution { public boolean isPalindrome(String s) {
        s = s.toLowerCase();
        for(int i=0, j = s.length() - 1;i<j;i++,j--){
            while(i < j && !(s.charAt(i) >= 'a' && s.charAt(i) <= 'z' || s.charAt(i) >= '0' && s.charAt(i) <= '9')) i++;
            while(i < j && !(s.charAt(j) >= 'a' && s.charAt(j) <= 'z' || s.charAt(j) >= '0' && s.charAt(j) <= '9')) j--;
    
            if(s.charAt(i) != s.charAt(j)){
                return false;
            }
        }
        
        return true;
    }
    }
    

    相关文章

      网友评论

          本文标题:leetcode125:验证回文字符串

          本文链接:https://www.haomeiwen.com/subject/trrfrctx.html