lst=[eval(x) for x in input().split(",")]
lst2=[]
[lst2.append(i) for i in lst if not i in lst2]
print(lst2)
i=0
for i in range(len(lst2)):
print(i)
if lst[i]==1 or lst[i]==2 or lst[i]==3 or lst[i]==4 or lst[i]==5:
lst[i]=0
print(lst2)
出错原因: 我在动态移除lst2里的元素,所以对应的lst2的长度和下标都会有所减少和变化,导致的错误。
关于这道题我是想改成代码注释里(1)那行那样,将要去掉的位置变为0,之后再统一去掉为0 的元素。
但是和学姐讨论之后得到了新的思路(所以相当于没改这个错了。。。因为我急着准备明天数据结构考试。。):
可以遍历一下然后有选择性的输出
新思路代码为
l=list(map(int,input().split(",")))
z=[0,0,0,0,0]
for i in l:
if i==6:
z[0]+=1
elif i==7:
z[1]+=1
elif i==8:
z[2]+=1
elif i==9:
z[3]+=1
elif i==10:
z[4]+=1
for i in range(len(z)):
if z[i]==0:
print(i+6,end=" ")
题目写在最下面吧,因为主要是想记录以下这个错误。(以后改!
【描述】 分析活动投票情况。第一小队有五名队员,序号是1、2、3、4、5;第二小队也有五名队员,序号6、7、8、9、10。输入一个得票字符串,求第二小队没有得票的队员序号。 【输入】 在一行中输入得票的队员的序列号,用逗号隔开。 【输出】 在一行中输出第二小队没有得票的队员序号。 【输入示例】
1,5,9,3,9,1,1,7,5,7,7,3,3,1,5,7,4,4,5,4,9,5,10,9 【输出示例】 6 8
|