给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例 1:
输入: "A man, a plan, a canal: Panama"
输出: true
示例 2:
输入: "race a car"
输出: false
C++1
class Solution {
public:
bool isPalindrome(string s) {
if(s.empty()){
return true;
return true;
}
vector<char> str;
for(int i=0;i<s.length();i++){
if(isalpha(s[i]) || isdigit(s[i])){
str.push_back(s[i]);
}
}
int flag = 1;
for(int j=0;j<str.size()/2;j++){
if(tolower(str[j]) != tolower(str[str.size()-j-1])){
flag = 0;
break;
}
}
if(flag == 0)
return false;
return true;
}
};
C++2
对撞指针法,两个下标在两头向中心靠近,遇到不是数字和字母的字符就跳过,直到两个指针相撞。
class Solution {
public:
bool isPalindrome(string s) {
int len = s.length();
int i=0, j = len-1;
while(i<j){
if(!isalnum(s[i])){
i++;
continue;
}
if(!isalnum(s[j])){
j--;
continue;
}
if(tolower(s[i]) != tolower(s[j]))
return false;
i++;
j--;
}
return true;
}
};








网友评论