leetcode125:验证回文字符串

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

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

示例 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;
}
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容