代码拉取完成,页面将自动刷新
/* 验证回文串
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例 1:
输入: "A man, a plan, a canal: Panama"
输出: true
解释:"amanaplanacanalpanama" 是回文串
示例 2:
输入: "race a car"
输出: false
解释:"raceacar" 不是回文串*/
class Solution
{
public:
//判断字母和数字字符
bool IsLetterorNumber(char ch)
{
return ('0'<=ch && ch<='9')
|| ('a'<=ch && ch<='z');
}
bool isPalindrome(string s)
{
//全部大写字母转换为小写字母
for(auto& ch : s)
{
if('A'<=ch && ch<='Z')
{
ch+=32;
}
}
//前后比较
int left = 0, right = s.size()-1;
while(left < right)
{
while(left<right && !IsLetterorNumber(s[left])) //是字母和数字字符时停下来
{
++left;
}
while(left<right && !IsLetterorNumber(s[right]))
{
--right;
}
//对比
if(s[left]!=s[right])
{
return false;
}
else
{
++left;
--right;
}
}
//此处全部符合
return true;
}
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。