返回介绍

solution / 0100-0199 / 0125.Valid Palindrome / README

发布于 2024-06-17 01:04:04 字数 5798 浏览 0 评论 0 收藏 0

125. 验证回文串

English Version

题目描述

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

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

给你一个字符串 s,如果它是 回文串 ,返回 true_ _;否则,返回_ _false_ _。

 

示例 1:

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

示例 2:

输入:s = "race a car"
输出:false
解释:"raceacar" 不是回文串。

示例 3:

输入:s = " "
输出:true
解释:在移除非字母数字字符之后,s 是一个空字符串 "" 。
由于空字符串正着反着读都一样,所以是回文串。

 

提示:

  • 1 <= s.length <= 2 * 105
  • s 仅由可打印的 ASCII 字符组成

解法

方法一:双指针

我们用双指针 $i$ 和 $j$ 分别指向字符串 $s$ 的两端,接下来循环以下过程,直至 $i \geq j$:

  1. 如果 $s[i]$ 不是字母或数字,指针 $i$ 右移一位,继续下一次循环;
  2. 如果 $s[j]$ 不是字母或数字,指针 $j$ 左移一位,继续下一次循环;
  3. 如果 $s[i]$ 和 $s[j]$ 的小写形式不相等,返回 false
  4. 否则,指针 $i$ 右移一位,指针 $j$ 左移一位,继续下一次循环。

循环结束,返回 true

时间复杂度 $O(n)$,其中 $n$ 是字符串 $s$ 的长度。空间复杂度 $O(1)$。

class Solution:
  def isPalindrome(self, s: str) -> bool:
    i, j = 0, len(s) - 1
    while i < j:
      if not s[i].isalnum():
        i += 1
      elif not s[j].isalnum():
        j -= 1
      elif s[i].lower() != s[j].lower():
        return False
      else:
        i, j = i + 1, j - 1
    return True
class Solution {
  public boolean isPalindrome(String s) {
    int i = 0, j = s.length() - 1;
    while (i < j) {
      if (!Character.isLetterOrDigit(s.charAt(i))) {
        ++i;
      } else if (!Character.isLetterOrDigit(s.charAt(j))) {
        --j;
      } else if (Character.toLowerCase(s.charAt(i)) != Character.toLowerCase(s.charAt(j))) {
        return false;
      } else {
        ++i;
        --j;
      }
    }
    return true;
  }
}
class Solution {
public:
  bool isPalindrome(string s) {
    int i = 0, j = s.size() - 1;
    while (i < j) {
      if (!isalnum(s[i])) {
        ++i;
      } else if (!isalnum(s[j])) {
        --j;
      } else if (tolower(s[i]) != tolower(s[j])) {
        return false;
      } else {
        ++i;
        --j;
      }
    }
    return true;
  }
};
func isPalindrome(s string) bool {
  i, j := 0, len(s)-1
  for i < j {
    if !isalnum(s[i]) {
      i++
    } else if !isalnum(s[j]) {
      j--
    } else if tolower(s[i]) != tolower(s[j]) {
      return false
    } else {
      i, j = i+1, j-1
    }
  }
  return true
}

func isalnum(ch byte) bool {
  return (ch >= 'A' && ch <= 'Z') || (ch >= 'a' && ch <= 'z') || (ch >= '0' && ch <= '9')
}

func tolower(ch byte) byte {
  if ch >= 'A' && ch <= 'Z' {
    return ch + 32
  }
  return ch
}
function isPalindrome(s: string): boolean {
  let i = 0;
  let j = s.length - 1;
  while (i < j) {
    if (!/[a-zA-Z0-9]/.test(s[i])) {
      ++i;
    } else if (!/[a-zA-Z0-9]/.test(s[j])) {
      --j;
    } else if (s[i].toLowerCase() !== s[j].toLowerCase()) {
      return false;
    } else {
      ++i;
      --j;
    }
  }
  return true;
}
impl Solution {
  pub fn is_palindrome(s: String) -> bool {
    let s = s.to_lowercase();
    let s = s.as_bytes();
    let n = s.len();
    let (mut l, mut r) = (0, n - 1);
    while l < r {
      while l < r && !s[l].is_ascii_alphanumeric() {
        l += 1;
      }
      while l < r && !s[r].is_ascii_alphanumeric() {
        r -= 1;
      }
      if s[l] != s[r] {
        return false;
      }
      l += 1;
      if r != 0 {
        r -= 1;
      }
    }
    true
  }
}
/**
 * @param {string} s
 * @return {boolean}
 */
var isPalindrome = function (s) {
  let i = 0;
  let j = s.length - 1;
  while (i < j) {
    if (!/[a-zA-Z0-9]/.test(s[i])) {
      ++i;
    } else if (!/[a-zA-Z0-9]/.test(s[j])) {
      --j;
    } else if (s[i].toLowerCase() !== s[j].toLowerCase()) {
      return false;
    } else {
      ++i;
      --j;
    }
  }
  return true;
};
public class Solution {
  public bool IsPalindrome(string s) {
    int i = 0, j = s.Length - 1;
    while (i < j) {
      if (!char.IsLetterOrDigit(s[i])) {
        ++i;
      } else if (!char.IsLetterOrDigit(s[j])) {
        --j;
      } else if (char.ToLower(s[i++]) != char.ToLower(s[j--])) {
        return false;
      }
    }
    return true;
  }
}
class Solution {
  /**
   * @param String $s
   * @return Boolean
   */
  function isPalindrome($s) {
    $regex = '/[a-z0-9]/';
    $s = strtolower($s);
    preg_match_all($regex, $s, $matches);
    if ($matches[0] == null) {
      return true;
    }
    $len = floor(count($matches[0]) / 2);
    for ($i = 0; $i < $len; $i++) {
      if ($matches[0][$i] != $matches[0][count($matches[0]) - 1 - $i]) {
        return false;
      }
    }
    return true;
  }
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文