题目描述:
给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为1000。
示例 1:
1 | 输入: "babad" |
示例 2:
1 | 输入: "cbbd" |
感悟:
- 一定要审好题。。。一开始想当然的认为自己理解了什么是回文子串。其实理解错误,然后再重头开始做,浪费时间。所以,一定要明白自己在做什么。
- 要灵活,想问题要灵活,换个角度来思考一下,有没有更容易的解决办法,可以类比一下。关于算法问题,常用的几类解题方法更要稔熟于心。具体的多看别人总结的知识,学习别人的知识,总比自己瞎想要系统,要全面,当然如果自己不去思考,那也白看。(1) https://blog.csdn.net/int1282951082/article/details/52128991 (2) https://www.cnblogs.com/ganhang-acm/p/3860361.html
- 在LeetCode上面,有解答的问题,一定要看一下别人的解答。先自己思考怎么做,然后再看别人的解题思路。
解题思路:
一开始我的解题思路就是暴力做。
- 固定起始字符,选择首尾字符相同的最大字符串,然后判断其是不是回文串,如果是,与最大length比较,比之大的话,则更新最大length和相应的串结果result
- 上一步固定起始字符,获得的最大字符,如果不满足的话,则选择第二大的字符,继续判断。
- 然后再继续固定下一个字符,继续循环。
中间可以加入停止状态,当剩余串长度小于最大length的时候,就可以停止了。当然这个办法是非常耗时的,尤其是判断是否是回文字符串时。
额…. 就在刚才,写着写着,突然想起来,好像可以改进一下判断方法,结果,提交之后通过了。之前一直是超时状态。
原来判断是回文字符串的方法是:
1 | def judge(str): |
其实,只要将字符串倒序一下,然后判断是否相同即可。。。唉
1 | def judge2(str): |
另一种思路:
当然,这题可以从另外的角度来做。
比如说,先将字符串倒序,然后寻找两字符串最大公共子串。这个方法应该挺常用的。
寻找最大公共子串的主要思路就是用一个矩阵,将两个字符串分别作为行和列,简单画个图表示就是:
用矩阵记录字符串相等的情况,矩阵某位置的值 = 左上角 + 1(如果相同,否则为0)
在得到最大公共子串之后,则可以继续判断公共子串的起始位置,在原始的两字符串中是否一样,如果一样的话,则说明找到了回文串,如果不一样的话,需要再找第二大的公共子串,重复该过程。
代码实现:
GitHub地址:https://github.com/zhangdianlei/LeetCode_python/blob/master/src/c05.py
1 | def judge(str): |