#主要元素改造一下即可使用(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 是主要元素
----
遍历。