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
相关推荐
CQ_YM12 分钟前
数据结构之栈
数据结构·算法·
爱学习的梵高先生26 分钟前
C++:基础知识
开发语言·c++·算法
xlq2232234 分钟前
24.map set(下)
数据结构·c++·算法
繁华似锦respect1 小时前
C++ & Linux 中 GDB 调试与内存泄漏检测详解
linux·c语言·开发语言·c++·windows·算法
立志成为大牛的小牛1 小时前
数据结构——五十四、处理冲突的方法——开放定址法(王道408)
数据结构·学习·程序人生·考研·算法
代码游侠2 小时前
复习——栈、队列、树、哈希表
linux·数据结构·学习·算法
碧海银沙音频科技研究院2 小时前
基于物奇wq7036与恒玄bes2800智能眼镜设计
arm开发·人工智能·深度学习·算法·分类
小白程序员成长日记3 小时前
2025.12.03 力扣每日一题
算法·leetcode·职场和发展
元亓亓亓3 小时前
LeetCode热题100--20. 有效的括号--简单
linux·算法·leetcode
熊猫_豆豆3 小时前
LeetCode 49.字母异位组合 C++解法
数据结构·算法·leetcode