Leetcode刷题-字符串125:验证回文串

该博客介绍了LeetCode中关于验证回文串的问题,包括问题描述、解决方法和关键点。通过分析思路,提出了两种方法:先处理字符串再判断回文,以及使用双指针。同时,讲解了Python中处理字符串的相关函数,如isalnum()、lower()等,帮助理解解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:

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

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

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

示例1:

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

示例2:

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

示例3:

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

提示:

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

分析思路

法1:先处理字符串再判断,即去除字符串中非字母或数字字符,然后通过比较处理后的字符串是否与其翻转后的字符串相等,从而判断出它是不是回文串;

法2:利用双指针

本题需要注意的点在于字符串相关函数的应用:

(1)如何判断字符串中的字符是不是字母或数字字符?(利用strings.isalnum()函数进行判断)

(2)如何将大写字母变为小写字母?(利用string.lower()函数)

(3)如何判断是否回文串?(s[::-1]表示字符串s逆序,可以通过判断 s == s[::-1]来判断,也可以通过双指针来实现)

此外,s.join(iterable)用于把字符串用指定的符号链接起来,返回字符串格式,其中s表示需要的分隔符,iterable表示被分割的对象,按字面理解就是s和iterable作用正好和实际交换。如下:

list = ['1','2','3','4','5']
s = '*'
#将字符串s与list中的每个元素值分别进行连接,然后再把连接的结果进行合并
print(s.join(list))
#输出结果:1*2*3*4*5

法1:

class Solution(object):
    def isPalindrome(self, s):
        """
        :type s: str
        :rtype: bool
        """
        new_s = ''
        #遍历字符串,将字符串中属于字符或数字的字符变为小写,并添加到新的字符串中
        for i in s:
            if i.isalnum():
                new_s += i.lower()
        return new_s == new_s[::-1]

代码精简后:
class Solution(object):
    def isPalindrome(self, s):
        """
        :type s: str
        :rtype: bool
        """
        s = ''.join([i for i in s if i.isalnum()]).lower()
        return s == s[::-1]

法2:

class Solution:
    def isPalindrome(self, s: str) -> bool:
        s = s.lower()
        left, right = 0, len(s) - 1
        while left < right:
            # 两个循环找到左侧和右侧为字母或者数字的位置
            while left < len(s) - 1 and not s[left].isalnum():
                left += 1
            while right > 0 and not s[right].isalnum():
                right -= 1
            if left >= right:  # 判断移动过后的left right是否满足left在左,right在右的相对位置
                break
            else:
                if s[left] != s[right]:  # 如果左右指针所指不同,则肯定不构成回文
                    return False
                else:  # 左右指针各前进一步
                    left += 1
                    right -= 1
        return True


作者:LotusPanda
链接:https://leetcode.cn/problems/valid-palindrome/solution/xiong-mao-shua-ti-python3-fu-xi-tie-hui-gu-chang-y/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

最后,回顾一下 Python 中常用处理字符串的相关函数

string.capitalize() 把字符串的第一个字符大写
string.count(str, beg=0, end=len(string)) 返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数
string.endswith(obj, beg=0, end=len(string)) 检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.
string.find(str, beg=0, end=len(string)) 检测 str 是否包含在 string 中,如果 beg 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回-1
string.index(str, beg=0, end=len(string))find()方法一样,只不过如果str不在 string中会报一个异常.
string.isalnum() 如果 string 至少有一个字符并且所有字符都是字母或数字则返回 True,否则返回 False
string.isalpha() 如果 string 至少有一个字符并且所有字符都是字母则返回 True,否则返回 False
string.isdecimal() 如果 string 只包含十进制数字则返回 True 否则返回 False.
string.isdigit() 如果 string 只包含数字则返回 True 否则返回 False.
string.islower() 如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False
string.isnumeric() 如果 string 中只包含数字字符,则返回 True,否则返回 False
string.isspace() 如果 string 中只包含空格,则返回 True,否则返回 False.
string.istitle() 如果 string 是标题化的(见 title())则返回 True,否则返回 False
string.isupper() 如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False
string.join(seq) 以 string 作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串
string.lower() 转换 string 中所有大写字符为小写.
string.lstrip() 截掉 string 左边的空格
max(str) 返回字符串 str 中最大的字母。
min(str) 返回字符串 str 中最小的字母。
string.replace(str1, str2, num=string.count(str1)) 把 string 中的 str1 替换成 str2,如果 num 指定,则替换不超过 num 次.
string.split(str="", num=string.count(str)) 以 str 为分隔符切片 string,如果 num 有指定值,则仅分隔 num+ 个子字符串
string.startswith(obj, beg=0,end=len(string)) 检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查.
string.strip([obj]) 在 string 上执行 lstrip()和 rstrip()
string.swapcase() 翻转 string 中的大小写
string.title() 返回"标题化"的 string,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())
string.translate(str, del="") 根据 str 给出的表(包含 256 个字符)转换 string 的字符,要过滤掉的字符放到 del 参数中
string.upper() 转换 string 中的小写字母为大写

作者:LotusPanda
链接:https://leetcode.cn/problems/valid-palindrome/solution/xiong-mao-shua-ti-python3-fu-xi-tie-hui-gu-chang-y/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值