Longest Palindromic Substring

本文介绍了一种解决LeetCode上最长回文子串问题的方法,通过统计字符串中字符的位置并检查子串是否为回文来寻找最长回文子串。此方法虽然简单直观,但在效率方面有待提高。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目详情:https://leetcode.com/problems/longest-palindromic-substring/description/

自己写的代码,思路:
1、统计s中元素出现的位置
2、然后遍历s中的每一个元素,设该元素的位置为nowPos
3、接着取下一个相同的元素的位置,设为nextPos,然后判s[nowPos,nextPos]是否为回文串,循环步骤3
4、循环步骤2,3
但是运行的时间有点长,leetCode给出的方法还没有看懂[衰]。

# -*- coding:utf-8 -*-
class Solution(object):
    def longestPalindrome(self, s):
        """
        :type s: str
        :rtype: str
        """
        i,length,d=0,len(s),{}
        if len(set(s))==1:
            return s
        maxs=""
        while i<length:#首先统计s中的字符出现的位置
            if d.get(s[i])==None:#如果s[i]在之前未出现过
                d[s[i]]=[i]#那么将该位置添加到d中
            else:#s[i]在之前就已经出现过了
                d[s[i]].append(i)#直接添加该位置
            i=i+1#下标加1
        i=0
        while i<length:
            char=s[i]
            for pos in d[char]:#d[char]返回的是list,该list中存储的是char的位置
                temp=s[i:pos+1]#取得[i,pos]之间的元素
                reverse=temp[::-1]#倒置temp
                if reverse==temp and len(temp)>=len(maxs):#temp是回文串,并且长度较长
                    maxs=temp#那么更新maxs
            d[char].pop(0)#删除第一个元素
            i=i+1
        return maxs
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值