【LeetCode】#125验证回文串(Valid Palindrome)
题目描述
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例
示例 1:
输入: “A man, a plan, a canal: Panama”
输出: true
示例 2:
输入: “race a car”
输出: false
Description
Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignoring cases.
Note: For the purpose of this problem, we define empty string as valid palindrome.
Example
Example 1:
Input: “A man, a plan, a canal: Panama”
Output: true
Example 2:
Input: “race a car”
Output: false
解法
class Solution {
public boolean isPalindrome(String s) {
s = s.trim().toLowerCase();
int n=0, m=s.length()-1;
while(n<m){
if((s.charAt(n)>57 && s.charAt(n)<97) || s.charAt(n)>122 || s.charAt(n)<48){
n++;
continue;
}
if((s.charAt(m)>57 && s.charAt(m)<97) || s.charAt(m)>122 || s.charAt(m)<48){
m--;
continue;
}
if(s.charAt(n)!=s.charAt(m))
return false;
n++;
m--;
}
return true;
}
}