为什么超了啊??
这段代码13行为什么会超过列表长度???class Solution(object):
def longestPalindrome(self, s):
"""
:type s: str
:rtype: str
"""
max_length=0
final_start=0
final_end=0
dp=[ for i in range(len(s))]
for end in range(1,len(s)):
for start in range(end):
if s==s and (end-start<2 or dp):
dp=True
if max_length<end-start+1:
final_start=start
final_end=end
length=end-start+1
return s(final_start,final_end+1)
dp 赋值为 [ for i in range(len(s))] 属于 len(s) 行 1 列 数据
假设 s 长度为 3 ,那么你 dp 生成的列表为:[, , ],读取 dp 时, start 范围为 0 ~ 2 ,end 只能等于 0
所以你 13 行 if 下的第一行代码 : dp[end]=True ,end 值只要超过 0 ,那么就或超出列表索引范围,因为 dp 为 len(s) * 1 维数据
dp=[ for i in range(len(s))]
产生的 dp
dp = [ , , ... ]
只能通过 dp 来访问列表中的元素
而这一句
if s==s and (end-start<2 or dp):
dp,end - 1 的值是 0 吗?
页:
[1]