《剑指offer》面试题18:有效的回文(此题中我用到了正则表达式,比作者的原答案简单一点)

"""
题目:给定一个字符串,请判断它是不是回文。假设只需要考虑字母和数字字符,并忽略大小写。
     回文,即从左到右,和从右到左的字符一样。如'Was it a cat I saw ?'就是一个回文。
解题思路:如果忽略标点符号和空格,定义两个指针,一个从字符串的开始位置向右移动,一个从字符串的末尾向左移动,判断二者是否持续相等即可,直到P1==P2
        双指针思路很关键,另外如何忽略掉字符串中的非数字和字母的字符也很关键。此处我用到了正则表达式,将原字符串进行过滤,只保留字母和数字。
        另外多说一点,如果要学好字符串的处理,正则表达式是必须要学习的东西。
        正则表达式推荐学习地址:https://www.runoob.com/python/python-reg-expressions.html
"""
import re


def is_mirror(s):
    # 下面的两行使用正则表达式对s进行处理,使新的new_s只包含s中的字母和数字。(我知道正则表达式中的a-z多余,在这里只是想做个笔记。)
    pattern = re.compile('[a-zA-Z0-9]')
    new_s = pattern.findall(s.upper())
    print(new_s)
    p1 = 0
    p2 = len(new_s)-1
    while p1 != p2:
        if new_s[p1] != new_s[p2]:
            return False
        p1 += 1
        p2 -= 1
    return True

s = 'Was it a cat I saw ?'
print(is_mirror(s))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值