当前位置: 首页 > news >正文

力扣HOT100之多维动态规划:5. 最长回文子串


这道题属于动态规划板块,但是我感觉这道题用动态规划相当晦涩难懂,看了一圈题解发现还是中心扩散法最好用,感觉这道题没有必要为了动态规划而动态规划,中心扩散法我感觉华南溜达虎的思路讲得很不错,非常通俗易懂,代码风格也很好,可以去看看他的视频。这道题就不用动态规划来做了,以后笔试面试遇到这道题就直接用中心扩散法了。
所谓中心扩散法,就是我们遍历字符串的每一个字符,并以该字符为中心,利用左右指针向两边扩散,如果左右指针指向的字符相等,则说明当前依然维护着回文子串的性质,我们可以进一步将左右指针向两边移动,当左右指针出现越界或者左右指针指向的字符不相等时退出循环。由于题目要求的是最长的回文子串,而不仅仅是最长的回文子串的长度,因此我们在循环中需要比较最长回文子串的长度与当前回文子串的长度,如果当前回文子串的长度更长,则更新最长回文子串的长度,并记下此时回文子串的起始下标。
我们注意到回文子串的长度可能是奇数,也可能是偶数,因此我们需要分类讨论:

1.回文子串长度为奇数的情况

例如字符串"abcbd",当我们从字符'c'开始向两边扩散时,起始位置i = 2left = i, right = i;,很显然,经过循环后,我们找到的最长回文子串为bcb,但是对于字符串abba,当我们从第二个'b'开始从两边扩散时,如果还是按照left = i, right = i;的初始化方式,一定找不到abba这个最长回文子串,这就说明我们在选择每一个扩散中心时,当left指针和right指针指向同一个字符作为初始化操作时,只能找到长度为奇数的最长回文字串,我们在统计完奇数情况后,还应当及时统计偶数情况,以免遗漏情况。

2.回文子串长度为偶数的情况

例如字符串abccba,当我们遍历到第一个a时,应当让left指向第一个aright指向第一个b,然后向两边扩散,很显然,在这种情况下得不到回文子串,遍历下一个字符。当遍历到第一个b时,让left指向第一个bright指向第一个c,很显然,在这种情况下得不到回文子串,遍历下一个字符。当遍历到第一个c时,让left指向第一个cright指向第二个c,在这种情况下,我们就得到了最长回文子串abccba,长度为偶数。
在理解了奇数和偶数情况下各自的初始化方式后,我们就很容易写出代码了,我们通过一个for循环遍历字符串s所有的字符,分别讨论对应的奇数和偶数回文子串的情况,不断维护最长回文子串的长度及对应的起始下标,在for循环结束后,直接调用s.substr()获取最长回文子串并返回即可。

class Solution {
public:string longestPalindrome(string s) {int result_len = 0;int result_start = 0;for(int i = 0; i < s.size(); i++){//长度为奇数的回文子串int left = i, right = i;while(left >= 0 && right < s.size() && s[left] == s[right]){if(right - left + 1 > result_len){  //遇到更长的回文子串result_len = right - left + 1;  //更新长度result_start = left;   //记录起点}left--;right++;}//长度为偶数的回文子串left = i, right = i + 1;while(left >= 0 && right < s.size() && s[left] == s[right]){if(right - left + 1 > result_len){  //遇到更长的回文子串result_len = right - left + 1;   //更新长度result_start = left;    //记录起点}left--;right++;}}string result = s.substr(result_start, result_len);return result;}
};
http://www.lqws.cn/news/111169.html

相关文章:

  • 软件评测师 综合测试 真题笔记
  • Spring @Autowired自动装配的实现机制
  • Silky-CTF: 0x02靶场
  • ADI硬件笔试面试题型解析上
  • spring boot应答500问题跟踪
  • 帝可得- 人员管理
  • CppCon 2014 学习:CONVERGENT EVOLUTION
  • Redis线程模型
  • 解决CSDN等网站访问不了的问题
  • Cursor使用最佳实践总结
  • 枫之谷Artale端午节大当机----后端技术的巨大风险
  • 涂装协作机器人:重新定义涂装工艺的智能化未来
  • Matlab回归预测大合集又更新啦!新增2种高斯过程回归预测模型,已更新41个模型!性价比拉满!
  • QGIS 矢量数据属性表中文乱码解决方案:4 步修复编码匹配问题
  • 高性能MCU的MPU与Cache优化详解
  • 降本增效的新引擎:GEO如何提升企业营销ROI
  • SKUA-GOCAD入门教程-第八节 线的创建与编辑2
  • 板凳-------Mysql cookbook学习 (九--3)
  • 大模型的分词器——算法及示例
  • 实战商品订单秒杀设计实现
  • 飞牛fnNAS存储模式RAID 5数据恢复
  • 简单transformer运用
  • 第七章 7.Warm Up Packet Tracer and IOS Basic (CCNA)
  • 中英混合编码解码全解析
  • 线程相关面试题
  • 【Zephyr 系列 5】定时器与低功耗控制:打造省电高效的嵌入式系统
  • 自然语言处理(NLP)的系统学习路径规划
  • IP查询与网络风险的关系
  • 小巧实用,Windows文件夹着色软件推荐
  • java int 颜色值转换为string 不带透明度