LeetCode 125. 验证回文串

发布于 2023-06-14 19:50:29 字数 3685 浏览 29 评论 0

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

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

示例 1:

输入: "A man, a plan, a canal: Panama"
输出: true
示例 2:

输入: "race a car"
输出: false


前置知识

  • 回文
  • 双指针

公司

  • 阿里
  • 腾讯
  • 百度
  • 字节
  • facebook
  • microsoft
  • uber
  • zenefits

思路

这是一道考察回文的题目,而且是最简单的形式,即判断一个字符串是否是回文。

针对这个问题,我们可以使用头尾双指针,

  • 如果两个指针的元素不相同,则直接返回 false,
  • 如果两个指针的元素相同,我们同时更新头尾指针,循环。 直到头尾指针相遇。

时间复杂度为 O(n).

拿 noon 这样一个回文串来说,我们的判断过程是这样的:

拿 abaa 这样一个不是回文的字符串来说,我们的判断过程是这样的:

关键点解析

  • 双指针

代码

  • 语言支持:JS,C++,Python,Java

JavaScript Code:

/*
 * @lc app=leetcode id=125 lang=javascript
 *
 * [125] Valid Palindrome
 */
// 只处理英文字符(题目忽略大小写,我们前面全部转化成了小写, 因此这里我们只判断小写)和数字
function isValid(c) {
  const charCode = c.charCodeAt(0);
  const isDigit =
  charCode >= "0".charCodeAt(0) && charCode <= "9".charCodeAt(0);
  const isChar = charCode >= "a".charCodeAt(0) && charCode <= "z".charCodeAt(0);

  return isDigit || isChar;
}
/**
 * @param {string} s
 * @return {boolean}
 */
var isPalindrome = function (s) {
  s = s.toLowerCase();
  let left = 0;
  let right = s.length - 1;

  while (left < right) {
  if (!isValid(s[left])) {
    left++;
    continue;
  }
  if (!isValid(s[right])) {
    right--;
    continue;
  }

  if (s[left] === s[right]) {
    left++;
    right--;
  } else {
    break;
  }
  }

  return right <= left;
};

C++ Code:

class Solution {
public:
  bool isPalindrome(string s) {
    if (s.empty())
      return true;
    const char* s1 = s.c_str();
    const char* e = s1 + s.length() - 1;
    while (e > s1) {
      if (!isalnum(*s1)) {++s1; continue;}
      if (!isalnum(*e)) {--e; continue;}
      if (tolower(*s1) != tolower(*e)) return false;
      else {--e; ++s1;}
    }
    return true;
  }
};

Python Code:

class Solution:
  def isPalindrome(self, s: str) -> bool:
    left, right = 0, len(s) - 1
    while left < right:
      if not s[left].isalnum():
        left += 1
        continue
      if not s[right].isalnum():
        right -= 1
        continue
      if s[left].lower() == s[right].lower():
        left += 1
        right -= 1
      else:
        break
    return right <= left

  def isPalindrome2(self, s: str) -> bool:
    """
    使用语言特性进行求解
    """
    s = ''.join(i for i in s if i.isalnum()).lower()
    return s == s[::-1]

Java Code:

class Solution {
  public boolean isPalindrome(String s) {
    int n = s.length();
    int left = 0, right = n - 1;
    while (left < right) {
      while (left < right && !Character.isLetterOrDigit(s.charAt(left))) {
        ++left;
      }
      while (left < right && !Character.isLetterOrDigit(s.charAt(right))) {
        --right;
      }
      if (left < right) {
        if (Character.toLowerCase(s.charAt(left)) != Character.toLowerCase(s.charAt(right))) {
          return false;
        }
        ++left;
        --right;
      }
    }
    return true;
  }
}

复杂度分析

  • 时间复杂度:$O(N)$
  • 空间复杂度:$O(1)$

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

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

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

0 文章
0 评论
24 人气
更多

推荐作者

13886483628

文章 0 评论 0

流年已逝

文章 0 评论 0

℡寂寞咖啡

文章 0 评论 0

笑看君怀她人

文章 0 评论 0

wkeithbarry

文章 0 评论 0

素手挽清风

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文