python 列表主要2元素(元素超1/3)
2022/2/25 12:51:25
本文主要是介绍python 列表主要2元素(元素超1/3),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
#主要元素改造一下即可使用(by 庞敏)-无问题20220225 #改造成2个主要元素,元素超过1/3即可 list=[2, 2, 4, 3, 3, 6, 2,7,8,9,2,3,2,3,2,3,2,3,7,3,2,3] l=len(list) a=[] print("元素有:",l,"个,主要元素要>=",(l/3))#要分奇偶数,这条不准。 for d1 in list: count=0 #count 放循环体里。如果在外面,则count原来越大 #i=list.index(d1) #d1元素的下标 for d2 in list: if d1==d2: count=count+1 #print([d1,count]) #计算,每个数值的重复次数 a.append([d1,count]) print(a) b=[] for each in a: #a列表去重 if each not in b: b.append(each) print("各元素出现的次数",b)#问题:每个元素只显示1次,去重 d=[] #可以优化这一步骤 ,把取值最大的数字赋值给max ll=len(b) for i in range(0,ll): c=b[i][1] d.append(c) d.sort() print("出现的次数排序",d) max=d[ll-1] max2=d[ll-2] #问题,max可能等于max2---用while解决。 while max!=max2: if max>=l/3: #print("存在主要元素") for j in range(0,ll): if max==b[j][1]: print(b[j][0],"是主要元素") if max2>=l/3: for j in range(0,ll): if max2==b[j][1]: print(b[j][0],"是主要元素") break while max==max2: if max>=l/3: #print("存在主要元素") for j in range(0,ll): if max==b[j][1]: print(b[j][0],"是主要元素") break
元素有: 22 个,主要元素要>= 7.333333333333333 [[2, 8], [2, 8], [4, 1], [3, 8], [3, 8], [6, 1], [2, 8], [7, 2], [8, 1], [9, 1], [2, 8], [3, 8], [2, 8], [3, 8], [2, 8], [3, 8], [2, 8], [3, 8], [7, 2], [3, 8], [2, 8], [3, 8]] 各元素出现的次数 [[2, 8], [4, 1], [3, 8], [6, 1], [7, 2], [8, 1], [9, 1]] 出现的次数排序 [1, 1, 1, 1, 2, 8, 8] 2 是主要元素 3 是主要元素
----
遍历。
这篇关于python 列表主要2元素(元素超1/3)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-08有遇到过吗?同样的规则 Excel 中 比Python 结果大
- 2024-03-30开始python成长之路
- 2024-03-29python optparse
- 2024-03-29python map 函数
- 2024-03-20invalid format specifier python
- 2024-03-18pool.map python
- 2024-03-18threads in python
- 2024-03-14python Ai 应用开发基础训练,字符串,字典,文件
- 2024-03-13id3 algorithm python
- 2024-03-13sum array elements python