def zhongshu(lista):
a=len(lista)
list2 = [1 for z in range(a)]
for i in range(a):
for j in range(i+1,a-1):
if lista[i] == lista[j]:
list2[i]+=1
lista.pop(j)
list2.pop(j)
max= list2[0]
b=0
for k in range(len(list2)):
if list2[k] > max:
max=list2[k]
b=k
return lista[b]
这是求一个列表里面的众数那吧?
你这个程序是有问题的:
首先你j的范围其实是到不了最后一个的,因此如果是[1, 2, 5, 3, 7, 0, 2],选择出来的众数会是1,这是因为根本不会到达最后一位;
其次如果一个值出现的次数大于2,你的就完全处理不了了,因为pop之后长度变了,如果是[1, 2, 1, 1, 2, 2, 5, 3],甚至会报错;
建议你换一种思路,例如使用字典什么的,给你个链接看一下有好多种方法:https://blog.csdn.net/weixin_41929524/article/details/86566784
def zhongshu(lista):
xdict = {k:0 for k in set(lista)}
for k in lista:
xdict[k] += 1
dv = 0
rk = None
for k,v in xdict.items():
if v>dv:
dv = v
rk = k
return rk
print(zhongshu([5,8,7,4,7,4,7,5,6]))
def zhongshu(lista):
lis = [(i, lista.count(i)) for i in set(lista)]
lis = sorted(lis, key=lambda x: x[1])
return lis.pop()[0]
print(zhongshu([1, 2, 3, 5, 5, 6, 5, 3, 2, 1, 2, 2, 1, 1, 3, 4, 5]))
lista.pop(j)出去后,长度变小了吧,最好是从大到小循环。
你这个函数要做什么功能?
您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632
非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!
速戳参与调研>>>https://t.csdnimg.cn/Kf0y