你不要修改正在循环的列表
改成这样
你题目的解答代码如下:
numbers = eval(input())
n = max(numbers)
m = min(numbers)
res = []
for i in numbers:
if i!=n and i!=m:
res.append(i)
print(res)
numbers = eval(input())
n = max(numbers)
m = min(numbers)
for i in range(len(numbers)-1,-1,-1):
if numbers[i]==n or numbers[i]==m:
numbers.pop(i)
print(numbers)
如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!
按个人理解,list.remove方法删除列表中某个元素后,该删除元素后的所有元素均前移1位,于是删除元素的后一位元素无法被循环遍历。当列表中存在相邻的最大最小元素时,上述代码有可能无法达到预期效果。
原址修改可以通过whlie循环try...except...来写
numbers = eval(input())
n = max(numbers)
m = min(numbers)
while True:
try:
numbers.remove(n)
except:
break
while True:
try:
numbers.remove(m)
except:
break
print(numbers)
非原址更简单
numbers = eval(input())
n = max(numbers)
m = min(numbers)
print([i for i in numbers if i not in (n, m)])
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!