Skip to main content

验证回文串

Tips

题目

给定一个字符串, 验证它是否是回文串, 只考虑字母和数字字符, 可以忽略字母的大小写. 说明: 本题中, 我们将空字符串定义为有效的回文串.

示例

输入: "A man, a plan, a canal: Panama"

输出: true

题解

这题不难, 定义前后两个指针往中间游走, 如果遇见非字母, 非数字字符, 或者空格, 那就跳过它们; 否则将对应的字符进行比较: 一旦不同, 说明不是回文; 一次遍历之后如果都相同, 说明是回文.

/**
* @param {string} s
* @return {boolean}
*/
var isPalindrome = function (s) {
const regex = /[A-Za-z0-9]/
let i = 0
let j = s.length - 1

while (i < j) {
if (!regex.test(s[i])) {
i++
}

if (!regex.test(s[j])) {
j--
}

if (regex.test(s[i]) && regex.test(s[j])) {
if (s[i].toLowerCase() !== s[j].toLowerCase()) return false
i++
j--
}
}

return true
}

扩展

\w 匹配字母, 数字, 下划线. 等价于 [A-Za-z0-9_].