如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个回文串。字母和数字都属于字母数字字符。
给你一个字符串 s,如果它是回文串 ,返回 true ;否则,返回 false 。
提示:
1 <= s.length <= 2 * 105
s
仅由可打印的 ASCII 字符组成
例子
示例 1:
输入: s = "A man, a plan, a canal: Panama"
输出:true
解释:"amanaplanacanalpanama" 是回文串。
示例 2:
输入:s = "race a car"
输出:false
解释:"raceacar" 不是回文串。
示例 3:
输入:s = " "
输出:true
解释:在移除非字母数字字符之后,s 是一个空字符串 "" 。
由于空字符串正着反着读都一样,所以是回文串。
解答
分析:使用双向指针 low 和 high,初始状态,low 指向 s 的最低位,high 指向 s 的最高位,在之后的操作中,low 从低位往高位移动,一次移动一步,high 从高位往低位移动,一次移动一步,它们每次移动结束,便比较所在位置的字符是否相同,不相同则说明 s 不是回文字符,相同则继续移动,直到 low === high
ts
function isPalindrome(s: string): boolean {
s = s.toLowerCase().replace(/[^a-z0-9]/g,'')
let low = 0
let high = s.length -1
let result = true
while(low < high) {
if (s[low] !== s[high]) {
result = false
break
}
low++
high--
}
return result
};