鱼C论坛

 找回密码
 立即注册
查看: 2891|回复: 7

为什么list index out of range

[复制链接]
发表于 2022-8-12 14:12:51 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. class Solution:
  2.     def lengthOfLongestSubstring(self, s: str) -> int:
  3.         x=0
  4.         m=0
  5.         listed=[]
  6.         for i,j in enumerate(s):
  7.             listed.extend(j)
  8.             while i+1<len(s):
  9.                  if listed[i] == listed[i+1]:
  10.                          if x<m:                    
  11.                              x=m
  12.                          m=0
  13.                  else:
  14.                       m+=1
  15.         print(x)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-8-12 14:18:47 | 显示全部楼层
本帖最后由 xruiy 于 2022-8-12 14:32 编辑

应将第九行改为:
if listed[i-1] == listed[i]
索引超出范围
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-12 14:30:28 | 显示全部楼层
当i=0的时候,listed的长度为1,if listed[i] == listed[i+1]: 这句话会造成下标越界。(其实所有情况都会越界,i其实就是数组的最大下标,任何时候i+1都会越界)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-12 14:32:41 | 显示全部楼层

if listed[i-1]==listed[i]
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-8-12 14:36:08 | 显示全部楼层
为什么已经改了还是超出时间限制
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-12 14:36:53 | 显示全部楼层
第9行  if listed[i] == listed[i+1]  列表索引超范围了

而且 第7行 listed.extend(j)  extend()函数参数是列表,而j是字符串     应改为  listed.extend([j])
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-8-12 15:01:17 | 显示全部楼层
append不能添加可迭代对象
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-12 16:23:51 | 显示全部楼层
改后代码:
  1. class Solution(object):
  2.     def lengthOfLongestSubstring(self, s):
  3.         """
  4.         :type s: str
  5.         :rtype: int
  6.         """
  7.         x=0
  8.         s_len = len(s)
  9.         for sub_start in range(s_len):
  10.             list = [s[sub_start]]
  11.             for i in range(sub_start + 1, s_len):
  12.                 if list.count(s[i]) == 0:
  13.                     list.append(s[i])
  14.                 else:
  15.                     break
  16.             sub_len = len(list)
  17.             if sub_len > x:
  18.                 x = sub_len
  19.         return x
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-27 15:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表