题目

给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。

示例 1:

输入: “babad”

输出: “bab”

注意: “aba” 也是一个有效答案。

示例 2:

输入: “cbbd”

输出: “bb”

来源:力扣(LeetCode)

人生苦短,我用python!简单的思路最适合大多数人!

python的精髓在于简单,灵活,用少的代码完成别的语言相同的工作!

最长回文字符串,我们看到这道题目,首先想到的是我们需要哪些数据,怎么操作!

数据

  1. 待处理的字符串,官方会给;
  2. 用来存储当前最长回文字符串的变量,控制子串长度的索引变量;
  3. 一些其他的中间变量;

思路

做过判断一个字符串是否是回文字符串的那道题时我们就知道,从中心向两边扩展依次比较对称位置是否相等就可以了。

从第一个字符往后遍历,把每个字符都当作中心去向两边扩散,当碰到边界停下;

两种情况

  1. 子串的形式为 ddbaabdd
  2. 子串的形式为 ddbabdd

边界

无论两种情况的哪一种,边界都是相同的, 即为下面while循环的条件

  1. 边界1是当控制子串的索引变量向左向右有一个碰到母串的边了;
  2. 边界2是字串在扩散的过程中,左边字符不等于右边字符,这样就不是回文字符串了;
class Solution:
def longestPalindrome(self, s: str) -> str:
temp, max_p, length = "", "", len(s) # 初始化一些要用的数据
for index in range(length): # 把每个字符都当作中心
index_left, index_right = index, index def compare(l, r): # 中心向两边扩散,两种形式的边界相同,所以一个函数搞定!
while l != -1 and r != length and s[l] == s[r]: # 边界
l, r = l-1, r+1 # 扩散
return s[l+1:r] if l == -1 or r == length else s[l+1:r] # 因为不同的边界条件返回的子串索引取值是有规律的! temp = compare(index_left, index_right) # 判断形式1是否存在
max_p = temp if len(temp) > len(max_p) else max_p # 判断是否比当前的回文字符串更长 try:s[index+1]
except:continue if s[index] == s[index+1]: # 判断形式2是否存在
left, right = index, index + 1
temp = compare(left, right) # 扩散
max_p = temp if len(temp) > len(max_p) else max_p # 判断是否比当前的回文字符串更长
return max_p # 返回最长回文字符串

代码解读:

max_p 是用来存放当前最长的回文子串;

compare函数,因为子串的形式只有两种,并且两种的边界都相同,那我们可以把两种给统一起来,用一个compare函数调用两次来完成;

try和except用异常捕获来判断当前字符的右面是否还有字符;当然也可以用当前字符索引和母串长度的关系来判断;

刚刚接触python不久!如果觉得能有所帮助的话,可以关注一下我的csdn博客(csdn博客:叫我明同学),也可以加一下我的python学习交流群:625988679 ;本人最近也是在准备考研,您的关注和支持可以无形之中增加我在复试中的表现,谢谢您!

python经典算法题:求字符串中最长的回文子串的更多相关文章

  1. c++ 获取字符串中最长的回文子串

    #include <vector> #include <iostream> #include <string> using namespace std; strin ...

  2. 给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为1000。

    给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为1000. 示例 1: 输入: "babad" 输出: "bab" 注意: &quo ...

  3. Longest Palindromic Substring - 字符串中最长的回文字段

    需求:Given a string S, find the longest palindromic substring in S. You may assume that the maximum le ...

  4. [经典算法题]寻找数组中第K大的数的方法总结

    [经典算法题]寻找数组中第K大的数的方法总结 责任编辑:admin 日期:2012-11-26   字体:[大 中 小] 打印复制链接我要评论   今天看算法分析是,看到一个这样的问题,就是在一堆数据 ...

  5. manacher算法处理最长的回文子串(一)

    引言 相信大家都玩过折叠纸张,如果把回文串相当于折叠一个A4纸,比如ABCDDCBA就是沿着中轴线(D与D之间)对折重合,那么这个就是一个回文串.或者是ABCDEDCBA的中轴线就是E,那么沿着中轴线 ...

  6. manacher算法处理最长的回文子串(二)

    在上篇<manacher算法处理最长的回文子串(一)>解释了manacher算法的原理,接着给该算法,该程序在leetcode的最长回文子串中通过.首先manacher算法维护3个变量.一 ...

  7. python经典算法题:Z字变形

    题目 直接看图! 思路第一步:分组 我们把传入的字符串进行分组, 每个框内的字母为1组: 我们发现每个相同颜色的框内的一组字母的特点是在传入的字符串中是连续的: 我们还发现每组字母的个数是由numRo ...

  8. python经典算法题:无重复字符的最长子串

    题目:无重复字符的最长子串. 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子 ...

  9. Manacher算法 O(n) 求最长回文子串

    转自:http://bbs.dlut.edu.cn/bbstcon.php?board=Competition&gid=23474 其实原文说得是比较清楚的,只是英文的,我这里写一份中文的吧. ...

随机推荐

  1. Python函数参数与参数解构

    1 Python中的函数 函数,从数学的角度来讲是,输入一个参数,经过一个表达式的处理后得到一个结果的输出,即就是x-->y的一个映射.同样,在Python或者任何编程语言中,函数其实就是实现一 ...

  2. linux系统下使用宝塔面板安装owncloud常见问题

    在安装owncloud时出现 无法写入“config”目录! 解决方法 在宝塔面板,找到owncloud根目录,点击"权限“设置权限 将权限设置为777,应用到子目录打勾(如下图) 确定后再 ...

  3. scipy.misc.toimage()出现toimage报错

    scipy.misc.toimage()出现toimage报错 自己被这个问题困扰了许久,其实最后发现其实toimage这个函数已经被取消了,或者说是没有这个函数了.有了新得函数与之代替,那就是Ima ...

  4. [NOIp2014] luogu P2312 解方程

    题目描述 已知方程∑i=0naixi=0\sum_{i=0}^{n}{a_ix^i}=0i=0∑n​ai​xi=0求该方程在 [1,m][1,m][1,m] 内的整数解. Solution 有一个秦九 ...

  5. [JZOJ5455]【NOIP2017提高A组冲刺11.6】拆网线

    Description 企鹅国的网吧们之间由网线互相连接,形成一棵树的结构.现在由于冬天到了,供暖部门缺少燃料,于是他们决定去拆一些网线来做燃料.但是现在有K只企鹅要上网和别人联机游戏,所以他们需要把 ...

  6. Mysql数据类型最细讲解

    文章原创于公众号:程序猿周先森.本平台不定时更新,喜欢我的文章,欢迎关注我的微信公众号. 数据库中事务是最重要的概念之一,所以上篇着重谈了谈数据库中事务的使用,并且举了实例如何在实际开发中去使用事务进 ...

  7. 【websocket】spring boot 集成 websocket 的四种方式

    集成 websocket 的四种方案 1. 原生注解 pom.xml <dependency> <groupId>org.springframework.boot</gr ...

  8. std::tuple

    tuple,元组类型.头文件<tuple>,tuple是一个固定大小的不同类型(异质,heterogeneous)值的集合(这一点是tuple与其他常规STL容器的最大不同,即它可以同时存 ...

  9. 使用css实现导航下方线条随导航移动效果

    HTML部分 <ul> <li><a href="">第一条</a></li> <li><a href ...

  10. vue element NavMenu 莫名出现蓝色边框

    最近在开发一款官网,使用的是element,在头菜单NavMenu,的时候没有设置任何的边框属性,结果出现了如下图所示的边框线. 点击有二级菜单时出现 找了好多方法发现是有一个属性影响到了,:focu ...