题目

给定一个字符串 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. Vue学习系列(二)——组件详解

    前言 在上一篇初识Vue核心中,我们已经熟悉了vue的两大核心,理解了Vue的构建方式,通过基本的指令控制DOM,实现提高应用开发效率和可维护性.而这一篇呢,将对Vue视图组件的核心概念进行详细说明. ...

  2. drf框架中所有视图及用法

    0909自我总结 drf框架中所有视图及用法 一.drf框架中的所有视图类 from django.views import View from rest_framework import views ...

  3. HTML5远程工具

    因为有从网页直接远程其他windows电脑的需求,于是通过网上搜索找到下面几个解决方案,分享一下: 1.windows的远程桌面web连接tsweb 下载地址https://www.microsoft ...

  4. 攻防世界(XCTF)WEB(进阶区)write up(三)

    挑着做一些好玩的ctf题 FlatScience web2 unserialize3upload1wtf.sh-150ics-04web i-got-id-200 FlatScience 扫出来的lo ...

  5. 三种常见字符编码:ASCII、Unicode和UTF-8

    什么是字符编码? 计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理.最早的计算机在设计时采用8个比特(bit)作为一个字节(byte),所以,一个字节能表示的最大的整数就是255( ...

  6. 修改配置文件application.properties

    附录A.常用应用程序属性 可以在application.properties文件内部application.yml,文件内部或命令行开关中指定各种属性.本附录提供了常见Spring Boot属性的列表 ...

  7. php数组怎么根据其中的一个值进行排序?解决方法

    有一个数组如下 我想对其进行一个排序,按照其“sort”的值的大小进行排序,3->4->7. 解决方法如下: 1.首先介绍php的两个方法 方法一:array_column() 返回输入数 ...

  8. Swoole 的微信扫码登录

    微信应用的便捷,扫码登录方式越来越被现在的应用所使用.它因为不用去记住密码,只要有微信号即可方便快捷登录.微信的开放平台原生就有支持扫码登录的功能,不过大部分人还是在用公众平台,所以扫码登录只能自行实 ...

  9. 徐明星系列之徐明星创办的OK资本成为RnF金融有限公司的锚定投资者

    12月17日,由区块链专家徐明星创办的OK集团的投资部门OK资本宣布,它将成为RnF金融有限公司的锚定投资者.OK集团成立于2012年,创始人徐明星是前豆丁网CTO,从豆丁网离职后,徐明星创办了OK集 ...

  10. 基于SkyWalking的分布式跟踪系统 - 环境搭建

    前面的几篇文章我们聊了基于Metrics的监控Prometheus,利用Prometheus和Grafana可以全方位监控你的服务器及应用的性能指标,在出现异常时利用Alertmanager告警及时通 ...