题目描述:
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例 1
输入: “A man, a plan, a canal: Panama”
输出: true
示例 2:
输入: “race a car”
输出: false
代码如下:
class Solution {
public:
bool isPalindrome(string s) {
int size=s.size();
string str;
bool flag=true;
if(size==0){
return flag;
}
for(int i=0;i<size;i++){
if(isalpha(s[i])){
str+=tolower(s[i]);
}
else if(isdigit(s[i])){
str+=s[i];
}
}
string ss(str);
reverse(ss.begin(),ss.end());
for(int j=0;j<=ss.size()/2;j++){
if(ss[j]!=str[j]){
flag=false;
break;
}
}
return flag;
}
};
执行结果: