leetcode刷题心得 005: Longest Palindromic Substring (最长回文字符串)

栏目: 编程工具 · 发布时间: 5年前

内容简介:题目地址:解题思路:第一步:循环字符串,每次循环时, 判断当前字符前一位和后一位是否相等,如果相等,说明是回文。然后再判断前一位的前一位和后一位的后一位是否相等。。。如此找出当前字符能拼出的最长回文。如下代码就是这个逻辑。

题目地址: https://leetcode.com/problems/longest-palindromic-substring/

解题思路:

第一步:循环字符串,每次循环时, 判断当前字符前一位和后一位是否相等,如果相等,说明是回文。然后再判断前一位的前一位和后一位的后一位是否相等。。。如此找出当前字符能拼出的最长回文。如下代码就是这个逻辑。

for i:=0;i<len(s);{
        // b 回文开始的位置 e 回文结束的位置
        b,e :=i,i
        //判断当前字符前一位和后一位是否相等,如果相等,说明是回文。然后再判断前一位的前一位和后一位的后一位是否相等。。。  (回文判断核心逻辑) 
        for e<len(s)-1 && b>0 && s[e+1] == s[b-1]{
            b--
            e++
        }
        newLength := e+1-b
        if newLength >maxLength{
            begin = b
            maxLength = newLength
        }
        i++
    }

第二步,第一步的逻辑是能够处理 bab bacab 这类奇数位的回文的,但是不能判断出 baab baccab 这种偶数位回文。所以需要在逻辑中加入处理偶数位回文的过程

for i:=0;i<len(s);{
        b,e :=i,i
        //现在e还是在回文的中间字符位置,如果e的下一位和e相等,就把下一位也一起当作回文的中间字符,再下一位同理
        for e<len(s)-1 &&s[e]==s[e+1]{
            e++
        }
        
        i = e+1
        for e<len(s)-1 && b>0 && s[e+1] == s[b-1]{
            b--
            e++
        }
        
        newLength := e+1-b
        if newLength >maxLength{
            begin = b
            maxLength = newLength
        }
        
    }

第三步,上面已经把核心逻辑写完了,但是有一些特殊情况没处理。首先就是判断字符串长度,当已知字符串长度小于2时。(就只给了一个字符)那一定是个回文。 下面贴出完整的代码

func longestPalindrome(s string) string {
    if len(s) < 2 { 
		return s
	}
    begin,maxLength := 0,1
    
    for i:=0;i<len(s);{
        
        
        b,e :=i,i
        
        for e<len(s)-1 &&s[e]==s[e+1]{
            e++
        }
        
        i = e+1
        for e<len(s)-1 && b>0 && s[e+1] == s[b-1]{
            b--
            e++
        }
        
        newLength := e+1-b
        if newLength >maxLength{
            begin = b
            maxLength = newLength
        }
        
    }
    return s[begin:begin+maxLength]
}

OK~如有疑问,欢迎交流。

标签:golang leetcode


以上所述就是小编给大家介绍的《leetcode刷题心得 005: Longest Palindromic Substring (最长回文字符串)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法详解(卷1)——算法基础

算法详解(卷1)——算法基础

[美]蒂姆·拉夫加登(Tim Roughgarden) / 徐波 / 人民邮电出版社 / 2019-1-1 / 49

算法是计算机科学领域最重要的基石之一。算法是程序的灵魂,只有掌握了算法,才能轻松地驾驭程序开发。 算法详解系列图书共有4卷,本书是第1卷——算法基础。本书共有6章,主要介绍了4个主题,它们分别是渐进性分析和大O表示法、分治算法和主方法、随机化算法以及排序和选择。附录A和附录B简单介绍了数据归纳法和离散概率的相关知识。本书的每一章均有小测验、章末习题和编程题,这为读者的自我检查以及进一步学习提......一起来看看 《算法详解(卷1)——算法基础》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具