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
相关推荐
2501_945424805 小时前
C++与硬件交互编程
开发语言·c++·算法
2301_818419015 小时前
C++中的表达式模板
开发语言·c++·算法
_日拱一卒6 小时前
LeetCode:三数之和
算法·leetcode·排序算法
cm6543206 小时前
C++中的原型模式变体
开发语言·c++·算法
☆5666 小时前
C++中的策略模式进阶
开发语言·c++·算法
dazzle6 小时前
机器学习算法原理与实践-入门(七):深度学习框架PyTorch的Tensor
深度学习·算法·机器学习
zbdx不知名菜鸡6 小时前
SwanLab 在监控什么?
人工智能·算法·机器学习
2301_822782826 小时前
嵌入式C++调试技术
开发语言·c++·算法
2301_776508726 小时前
实时信号处理库
开发语言·c++·算法
hans汉斯6 小时前
基于污点分析的PHP应用威胁检测平台
开发语言·人工智能·算法·yolo·目标检测·php·无人机