美文网首页
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