Fortsetzung von Letztes Mal Diesmal der Code, um den häufigsten Wert des Arrays zu finden Der Antwortcode in C ++ wurde bereits veröffentlicht, aber ich habe ihn in Python umgeschrieben.
test.cpp
int mostFrequent;
int highestFrequency = 0;
int currentFrequency = 0;
for (int i = 0; i < ARRAY_SIZE; i++){
currentFrequency++;
if (i == ARRAY_SIZE - 1 || surveyData[i] != surveyData[i + 1]){
if (currentFrequency > highestFrequency){
highestFrequency = currentFrequency;
mostFrequent = surveyData[i];
}
currentFrequency = 0;
}
}
test37.py
#!/usr/bin/env python
#coding:utf-8
import math
elem = [4,7,3,8,9,7,3,9,9,3,3,10]
###Ich repariere es
#count = {Elem.count(v):v for v in set(Elem)}
#high = max(count)
#most = count[high]
elem.sort()
most = 0
high = 0
current = 0
#for i,v in enumerate(Elem):
for i in range(len(elem)):
current += 1
if i == len(elem) - 1 or elem[i] != elem[i+1]:
if current > high:
high = current
most = elem[i]
current = 0
print('Array=',elem, '\n' , 'Häufigster Wert:',most,'|','Anzahl:',high)
・ ・ ・(Terminalausführung)
>>> import test37
Array= [3, 3, 3, 3, 4, 7, 7, 8, 9, 9, 9, 10]
Häufigster Wert: 3 |Anzahl: 4
>>>
Unter Ausnutzung der vorherigen Überlegungen dachte ich über die Verwendung von "Listeneinschlussnotation" und "Generatoreinschlussnotation" nach, aber da ich beim Teil von aktuell + = 1 zählen musste, wiederholte ich die obige if-Anweisung. Hat. Obwohl es einen Antwortcode gibt, braucht es Zeit, um ihn in Python zu ändern. Ich habe das Gefühl, dass ich mich daran gewöhnen muss.