题目名称

如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。

字母和数字都属于字母数字字符。

给你一个字符串 s,如果它是 回文串 ,返回 true ;否则,返回 false

示例

输入: s = “A man, a plan, a canal: Panama”
输出:true
解释:”amanaplanacanalpanama” 是回文串。

题解

首先通过正则表达式,替换掉所有非字母和数字的字符串,
然后利用双指针左右对比是否是回文字符串

答案

1
2
3
4
5
6
7
8
9
10
11
12
var isPalindrome = function(s) {
s = s.replace(/[^0-9a-zA-Z]/g, "").toLocaleLowerCase()
let left = 0, right = s.length - 1
while(left < right) {
if(s[left] !== s[right]) {
return false
}
left++
right--
}
return true
};