题目描述:
个人题解:在原字符串上直接判断
可以对方法一中第二种判断回文串的方法进行优化,就可以得到只使用 O(1) 空间的算法。直接在原字符串 s 上使用双指针。在移动任意一个指针时,需要不断地向另一指针的方向移动,直到遇到一个字母或数字字符,或者两指针重合为止。也就是说,每次将指针移到下一个字母字符或数字字符,再判断这两个指针指向的字符是否相同。
知识点回顾:
代码实现:
class Solution {
public:
bool isPalindrome(string s) {
int n = s.size();
if(n<=1) return true;
int left = 0, right = n - 1;
while (left < right) {
while (left < right && !isalnum(s[left])) {
++left;
}
while (left < right && !isalnum(s[right])) {
--right;
}
if (tolower(s[left]) != tolower(s[right])) {
return false;
}
++left;
--right;
}
return true;
}
};
复杂度分析:
时间复杂度:O(∣s∣),其中 ∣s∣ 是字符串 s 的长度。
空间复杂度:O(1)。
重点:熟练运用C++中与字符判断有关的内置函数