leetcode icon indicating copy to clipboard operation
leetcode copied to clipboard

125. 验证回文串

Open buuing opened this issue 3 years ago • 0 comments

给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。

说明:本题中,我们将空字符串定义为有效的回文串。

示例 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
}

buuing avatar Nov 12 '21 12:11 buuing