给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例 1:
输入: “A man, a plan, a canal: Panama”
输出: true
解释:“amanaplanacanalpanama” 是回文串
示例 2:
输入: “race a car”
输出: false
解释:“raceacar” 不是回文串
提示:
1 <= s.length <= 2 * 105
字符串 s 由 ASCII 字符组成
来源:力扣(LeetCode)
链接
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
方法一:筛选+判断
class Solution {
public:
bool isPalindrome(string s) {
string t;
for(char ch : s){
if(isalnum(ch)){
t.push_back(toupper(ch));
}
}
int n = t.size();
for(int i = 0; i < n / 2; ++i){
if(t[i] != t[n - 1 - i]) return false;
}
return true;
}
};
方法二:直接在原来的字符串上处理
class Solution {
public:
bool isPalindrome(string s) {
int n = s.size();
int left = 0, right = n - 1;
while(left < right){
while(left < right && !isalnum(s[left])) ++left;
while(left < right && !isalnum(s[right])) --right;
if(toupper(s[left]) != toupper(s[right])) return false;
++left;
--right;
}
return true;
}
};