我正在尝试为一个小程序编写代码,该程序将列表作为输入并返回一个布尔值,指示是否有任何连续重复的数字(列表必须至少有2个元素)。我一直收到以下错误:
IndexError: list index out of range.
任何关于如何解决这个问题的建议将不胜感激!
def two_length_run(n):
i = 0
while i < len(n):
if len(n) >= 2:
if (n[i] == n[i + 1]) and (n[i + 1] <= len(n)):
return True
else:
i = i + 1
else:
return False
k
的列表的索引为0:(k-1),但是您的测试允许i+1
运行到k
的值,这会导致您的访问超出范围。新检查:注意从<=
到<
的更改,并撤消订单。
if i + 1 < len(n) and n[i] == n[i+1]:
“短路”确保如果第一个条件为假,则不会评估第二个条件。
您可以使用for
循环更轻松地完成此操作,这有助于将您的idex保持在界限内:
if len(n) >= 2:
for i in range(len(n)-1):
if n[i] == n[i + 1]:
return True # Exit early if you find a pair
return False
我会这样写:
def two_length_run(n):
if not n or len(n) < 2:
return False
for i in xrange(len(n) - 1):
if n[i] == n[i+1]:
return True
return False
在开始迭代和使用xrange之前进行检查(快速退出),而不是手动增加“i”。
def two_length_run(n):
i = 0
while i < len(n):
if len(n) >= 2:
if (i + 1 < len( n )) and ( n[i] == n[i + 1]) and (n[i + 1] <= len(n)):
return True
else:
i = i + 1
else:
return False
当i = len(n) - 1时,内部if条件可能由于i + 1而溢出,所以在那里添加一个检查。
您的循环检查当前索引和下一个索引,因此您的while
条件不正确。
代替
while i < len(n):
if len(n) >= 2:
运用
if len(n) > 1:
while i < len(n) - 1:
if n[i] == n[i + 1]:
return True
i = i + 1
# Checked every index of n without a duplicate
return False
将避免此索引错误。
你得到的答案似乎是正确的。但是,我认为将条件放在while语句中会更清晰。
def two_length_run(n):
i = 0
while i < len(n) - 1:
if len(n) >= 2:
if (n[i] == n[i + 1]) and (n[i + 1] <= len(n)):
return True
else:
i = i + 1
else:
return False
我认为这应该有效