leetcode
                                
                                 leetcode copied to clipboard
                                
                                    leetcode copied to clipboard
                            
                            
                            
                        125. 验证回文串
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例 1:
输入: "A man, a plan, a canal: Panama"
输出: true
解释:"amanaplanacanalpanama" 是回文串
示例 2:
输入: "race a car"
输出: false
解释:"raceacar" 不是回文串
提示:
- 1 <= s.length <= 2 * 105
- 字符串 s 由 ASCII 字符组成
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/valid-palindrome 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
- 正则 + 双指针
const isPalindrome = s => {
  s = s.replace(/./g, res => {
    return /[0-9|a-z|A-Z]/.test(res) ? res.toLowerCase() : ''
  })
  let left = 0, right = s.length - 1
  while (left < right) {
    if (s[left++] !== s[right--]) return false
  }
  return true
}
- 双指针
const isPalindrome = s => {
  let left = 0, right = s.length - 1
  const reg = /[0-9|a-z|A-Z]/
  while (left < right) {
    if (!reg.test(s[left])) {
      left++
      continue
    }
    if (!reg.test(s[right])) {
      right--
      continue
    }
    if (s[left++].toLowerCase() !== s[right--].toLowerCase()) {
      return false
    }
  }
  return true
}