LeetCode 125.验证回文串

验证回文串

python 复制代码
class Solution:
    def isPalindrome(self, s: str) -> bool:
        #使用双指针法
        #创建左右两个指针,当左右指针位置不为数字或者字母时候,左指针往右移动,右指针往左移动 
        #然后判断左右两个指针所在是否相等,相等则接着循环,否则返回错误
        left, right=0, len(s)-1
        while left<right:
            while left<right and not  self.isright(s[left]):
                left+=1
            while left<right and not  self.isright(s[right]):
                right-=1
            if left<right and s[left].lower() != s[right].lower()  :
                return False
            left+=1
            right-=1
        return True
                
    def isright(self,s):
        return s.isdigit() or s.isalpha() 

函数 str.isdigit(),str.isalpha() 判断传递字符串是否为数字或者字母

函数 str.upper(),str.lower() 将字符串转化为大写或者小写

尽量写子函数,独立开来

相向指针中的Reverse型

先写逻辑再进行书写

验证回文串II

python 复制代码
class Solution:
    #双指针算法,相向双指针
    #做异常检测
    #判断是否为回文串的依据是findDifferent函数返回的left,right,如果 left>=right,则为回文串
    #先找出首先出现问题的left和right,如果 left>=right,则为回文串
    #否则,判断left+1,right或者left,right-1是否回文串
    def validPalindrome(self, s: str) -> bool:
        if s is None:
            return Flase

        left,right=self.findDifferent(s,0,len(s)-1)
        if left>=right:
            return True
        
        return self.isPalindrome(s,left+1,right) or self.isPalindrome(s,left,right-1)
    
    #判断是否为回文串
    def isPalindrome(self,s,left,right):
        left,right=self.findDifferent(s,left,right)
        return left>=right

    #找到出现问题的left,right所在位置,并返回left,right
    def findDifferent(self,s,left,right):
        while left<right:
            if s[left] != s[right]:
                return left,right
            left+=1
            right-=1
        return left,right
相关推荐
星谷罗殇8 小时前
(七)TRPO 算法 & PPO 算法
算法·机器学习
国服第二切图仔9 小时前
Rust开发之使用Trait对象实现多态
开发语言·算法·rust
电鱼智能的电小鱼10 小时前
基于电鱼 ARM 工控机的井下AI故障诊断方案——让煤矿远程监控更智能、更精准
网络·arm开发·人工智能·算法·边缘计算
s砚山s10 小时前
代码随想录刷题——二叉树篇(一)
c++·算法·leetcode
贝塔实验室13 小时前
LDPC 码的构造方法
算法·fpga开发·硬件工程·动态规划·信息与通信·信号处理·基带工程
Greedy Alg13 小时前
LeetCode 287. 寻找重复数
算法
2501_9387912213 小时前
逻辑回归与KNN在低维与高维数据上的分类性能差异研究
算法·分类·逻辑回归
南方的狮子先生13 小时前
【深度学习】60 分钟 PyTorch 极速入门:从 Tensor 到 CIFAR-10 分类
人工智能·pytorch·python·深度学习·算法·分类·1024程序员节
报错小能手14 小时前
C++笔记(面向对象)类模板
算法
JJJJ_iii14 小时前
【机器学习10】项目生命周期、偏斜类别评估、决策树
人工智能·python·深度学习·算法·决策树·机器学习