Häufigkeit d. Auftritts eines Wertes im Array

Status
Nicht offen für weitere Antworten.
G

Gast :D

Gast
Guten Tag,
ich stehe for folgendem Problem: Ich habe ein (zunächst ungeordnetes) eindimensionales int-array (z. B. {0,5,2,2,3,2,4} ) und will testen, wie oft ein Wert (sagen wir 1) darin vorkommt (wäre in diesem Fall 0 mal^^). Ich habe mich schonmal in der java API umgesehen, aber leider keine passende Methode gefunden. Gestoßen bin ich nur auf Quicksort und BinarySearch-Methoden. Daraus kann ich mir natürlich prinzipiell meine gewünschte Methode zusammenbauen, aber was mir zur Zeit vorschwebt* ist extrem aufwändig und ressourcenverschwenderisch. Meine Frage: Gibt es eine elegantere Möglichkeit und wie könnte man da rangehen?

* Hier mein jetziger Ansatz (leider noch keinen Quelltext geschrieben):
1. die Liste mit Quicksort sortieren.
2. mit binarySearch den Wert suchen
3. bei gefundenem Wert von da an mit ner while-Schleife weitergehen solange der Wert von m==m[i-1] ist. auf diese weise die elemente zählen.

Vielen Dank für eure etwaigen Mühen
 

function

Bekanntes Mitglied
wenn es nur eine überschaubare menge an möglichenwerten ist, würde ich mir einfach ein array erstellen, was genauso groß ist wie die möglichen auftauchenden ints.
beispiel:
mögliche zahlen: 0-5
ein array erstellen mit den indiezes von 0-5 und mit 0 setzen.
dann dein array durchlaufen und immer für die gefundene zahl den wert im "muster"array erhöhen.

falls in deinem array alle int werte möglich sind würde ich von dieser methode abstand nehmen. Und eine HashMap empfehlen.
Dann solltest du dein array durchlaufen und die gefundene zahl als key setzen und einen "counter" als value, falls ein key schon existiert value abrufen und erhöhen...
 
G

Guest

Gast
Code:
int a[] = { 0, 5, 2, 2, 3, 2, 4 };
int x = 2; // gesuchte Zahl
int n = 0; // Anzahl Vorkommen der gesuchten Zahl
Arrays.sort(a);
int index = Arrays.binarySearch(a, x);
if(index >= 0) {
   for(int i=index; i<a.length && a[i]==x; i++) {
      n++;
   }
   for(int i=index-1; i >= 0 && a[i]==x; i--) {
      n++;
   }
}
System.out.println(n);
oder einfach unsortiert alle durchgehen (ist schneller).
Code:
for(int i=0; i<a.length; i++) {
   if(a[i] == x) {
      n++;
   }
}
 
G

Gast :D

Gast
@function: An deine erstgenannte Variante hatte ich tatsächlich auch gedacht, habe ich aber bereits verworfen, denn der Bereich der möglichen Werte könnte bei mir in der Tat größer werden. Was die HashMap angeht: Dazu fehlen mir bisher die Kenntnisse. Hast mich jetzt aber neugierig gemacht und ich werd mich mal mit befassen, danke dir.

@Gast: Danke! Deine zweite Variante ist genau das, was ich gebraucht habe. Jetzt wird mir klar, dass ich viel zu kompliziert gedacht habe und die Lösung ja eigentlich recht trivial war! Soweit ich das beurteilen kann scheint die Komplexität ja noch in nem angemessenen Rahmen zu sein. Also vielen Dank dafür, dass du mir die Denkblockade aufgelöst hast ;)
 
G

Guest

Gast
Gast :D hat gesagt.:
@Gast: Danke! Deine zweite Variante ist genau das, was ich gebraucht habe. Jetzt wird mir klar, dass ich viel zu kompliziert gedacht habe und die Lösung ja eigentlich recht trivial war! Soweit ich das beurteilen kann scheint die Komplexität ja noch in nem angemessenen Rahmen zu sein. Also vielen Dank dafür, dass du mir die Denkblockade aufgelöst hast ;)
Man nimmt immer die einfachste Variante, die die vorliegende Aufgabe (noch) erfüllt. ;)
 
G

Guest

Gast
Code:
int a[] = { 0, 5, 2, 2, 3, 2, 4 }; 
int x = 2; // gesuchte Zahl 
List<Integer> intList = Arrays.asList( ints ); 
System.out.println( Collections.frequency( intList, x ));
 
G

Gast :D

Gast
Code:
int a[] = { 0, 5, 2, 2, 3, 2, 4 };
int x = 2; // gesuchte Zahl
List<Integer> intList = Arrays.asList( a );
System.out.println( Collections.frequency( intList, x ));

da krieg ich nen compilefehler in zeile 3:
incompatible types
found : java.util.List<int[]>
required: java.util.List<java.lang.Integer>
List<Integer> intList = Arrays.asList( a );

Den Fehler verstehe ich nicht ganz. Kann mir den jemand erklären? ~Danke
 

Joker

Bekanntes Mitglied
schreibe statt int Integer:

Code:
Integer a[] = { 0, 5, 2, 2, 3, 2, 4 }; 
	 int x = 2; // gesuchte Zahl 
	 List<Integer> intList = Arrays.asList( a ); 
	 System.out.println( Collections.frequency( intList, x ));
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Häufigkeit von Wörtern zählen Java Basics - Anfänger-Themen 6
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
Poppigescorn Häufigkeit einer zahl zählen Java Basics - Anfänger-Themen 5
H Häufigkeit von Zahlen ermitteln Java Basics - Anfänger-Themen 23
B Häufigkeit einzelner Zahlen in einem Array Java Basics - Anfänger-Themen 6
O FilterStream häufigkeit der Buchstaben Java Basics - Anfänger-Themen 43
B Array - die Häufigkeit der Zahl zählen Java Basics - Anfänger-Themen 9
B generische LinkedList nach Häufigkeit der Elemente füllen Java Basics - Anfänger-Themen 6
H Klassen varibale einer klasse in einer anderen klasse aufrufen und häufigkeit ausgeben Java Basics - Anfänger-Themen 22
F Häufigkeit von Buchstaben Java Basics - Anfänger-Themen 7
J Array nach häufigkeit sortieren Java Basics - Anfänger-Themen 4
J Zufallszahlen Häufigkeit Java Basics - Anfänger-Themen 8
P Hashtabelle-Häufigkeit von String zählen Java Basics - Anfänger-Themen 2
M Methoden String methoden ,Häufigkeit einm wort in der Zeichenkette Java Basics - Anfänger-Themen 14
Bastie Strings nach häufigkeit sortieren -aber wie? Java Basics - Anfänger-Themen 10
G Häufigkeit der Elemente in einer ArrayList zählen Java Basics - Anfänger-Themen 2
G Häufigkeit der Wörter einer Webseite zählen Java Basics - Anfänger-Themen 7
G absolute Häufigkeit Java Basics - Anfänger-Themen 13
E relative häufigkeit berechnen funktioniert nicht Java Basics - Anfänger-Themen 7
richis-fragen Ungefähre Restdauer eines Kopiervorgangs ermitteln Java Basics - Anfänger-Themen 3
D Erste Schritte Frage eines absoluten Anfängers Java Basics - Anfänger-Themen 3
R Operatoren Klausurenfrage: Auswertungspräzedenz eines komplizierten Ausdrucks Java Basics - Anfänger-Themen 6
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
P Wie kann ich beispielsweise Speicherstände eines Spiels DAUERHAFT in meinem Programm speichern? Java Basics - Anfänger-Themen 3
laxla123 Eigenschaften eines Algorithmus (determiniert vs.. deterministisch) Java Basics - Anfänger-Themen 2
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Fehler Semikolon fehlt - ich weiss aber nicht wo da noch eines hin sollte... Java Basics - Anfänger-Themen 21
J Farbe des Striches eines TitledBorders ändern Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
walid Öffnungszeiten eines Geschäftes Java Basics - Anfänger-Themen 3
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
U Eigenschaft eines JTextfiels per ActionListener ändern... Java Basics - Anfänger-Themen 2
B Synchronisation eines kleinen Museums Java Basics - Anfänger-Themen 47
krgewb Breite und Höhe eines Bildes in base64 auslesen Java Basics - Anfänger-Themen 3
Sachinbhatt Was ist die Notwendigkeit eines Sammlungsframeworks in Java? Java Basics - Anfänger-Themen 2
N Textdatei aus Resourcen-Ordner eines Projekts/ jar-file lesen Java Basics - Anfänger-Themen 4
B Produkt eines double - streams Java Basics - Anfänger-Themen 3
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
S Variablen Letzte Zeile eines Strings entfernen Java Basics - Anfänger-Themen 1
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
sserio Java Fx, wie erstellt man einen EventHandler, der durch das Drücken eines Button Texte in eine Table view einfügt Java Basics - Anfänger-Themen 17
J Größe eines Strings in Pixel Java Basics - Anfänger-Themen 18
M Parse-Tree eines statements darstellen Java Basics - Anfänger-Themen 0
H Java verkettete Liste, Wert eines Index zurückgeben Java Basics - Anfänger-Themen 1
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
J Hinzufügen eines Objektes in ein Objekt-Array Java Basics - Anfänger-Themen 62
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
A Rekursive Implementation eines Codes Java Basics - Anfänger-Themen 4
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
M Konstruktor ohne Übergabe eines Wertes Java Basics - Anfänger-Themen 7
M Wie kann ich in einem Konstruktor die Methode eines anderen Interfaces mit den jeweiligen Parametern aufrufen? Java Basics - Anfänger-Themen 8
M Wie erreiche ich das Vorwärtsgehen eines Roboters? Java Basics - Anfänger-Themen 2
M Wie erreiche ich es das Vorwärtsgehen eines Roboters? Java Basics - Anfänger-Themen 0
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
A Optimierung eines Programms: Mergen der Dateien Java Basics - Anfänger-Themen 23
melisax Alle Möglichkeiten eines Wortes angeben Java Basics - Anfänger-Themen 3
A Java, verarbeitung eines xml-files Java Basics - Anfänger-Themen 2
C Fehler beim erstellen eines Objektes Java Basics - Anfänger-Themen 3
B Konkatenieren eines Strings und inkremtierenden Zahl zu einer INT Variablen Java Basics - Anfänger-Themen 7
F Initialisieren eines Web-Mp3 Players in Tabs durch "booleans" erst wenn Tab geöffnet wird ...? Java Basics - Anfänger-Themen 1
P Drei Zahlen eines Würfelspiels auswerten Java Basics - Anfänger-Themen 7
C Brauche Hilfe beim Schreiben eines Programmes :/ Java Basics - Anfänger-Themen 1
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
C Überprüfen eines Programms auf Syntaxfehler Java Basics - Anfänger-Themen 3
S Wie kann ich den Bereich eines Integers begrenzen? Java Basics - Anfänger-Themen 2
nonickatall Grundsätzliches Verständnisproblem des Aufbaus eines Programms Java Basics - Anfänger-Themen 19
B Downgrade eines bestehenden Projektes Java Basics - Anfänger-Themen 5
amelie123456 Geschwindigkeit der Methode bewegeDich eines Objekts ändern Java Basics - Anfänger-Themen 2
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
J maximaler Wert eines Integers Java Basics - Anfänger-Themen 14
TimoN11 IntelliJ , Ausgabe von einem Quellcode in Eingabe eines Quellcodes Java Basics - Anfänger-Themen 1
Z Rückgabe eines Values in umgekehrte richtung Java Basics - Anfänger-Themen 5
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
B fragen zu Aufbau eines UML-Klassendiagramm Java Basics - Anfänger-Themen 1
eleonori Durchschnitt aller Werte eines Baums berechnen Java Basics - Anfänger-Themen 5
M Benutzereingabe eines Codes verbessern Java Basics - Anfänger-Themen 3
B Modulo-Operator anhand eines Beispieles erklären Java Basics - Anfänger-Themen 7
J Verschieben von Buchstaben in einem String um vorgegebene Anzahl von Zeichen innerhalb eines weiteren String Java Basics - Anfänger-Themen 12
F Auf Variablen eines Konstruktors zugreifen Java Basics - Anfänger-Themen 4
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
marcooooo Separator zwischen allen Zeichen eines Strings einfügen Java Basics - Anfänger-Themen 29
C Wie kann ich Versionen eines Projektes in Eclipse erstellen? Java Basics - Anfänger-Themen 3
yoskaem Text Color durch Klicken eines Buttons in anderer Activity ändern Java Basics - Anfänger-Themen 2
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
P Klasse hat keinen Zugriff auf getter/setter-Methoden eines Objektes Java Basics - Anfänger-Themen 9
R Löschen und ausgeben eines Teilbaums Java Basics - Anfänger-Themen 3
J Alle Werte eines Strings zusammen addieren Java Basics - Anfänger-Themen 15
M Hilfe bei Strukturierung eines Buchungssystems Java Basics - Anfänger-Themen 3
M Erstellen eines insets Objekts, GridBagLayout Java Basics - Anfänger-Themen 13
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14
W Random Zahl unter Berücksichtung eines Durchschnitts Java Basics - Anfänger-Themen 7
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
A Freie Stelle eines Arrays Java Basics - Anfänger-Themen 17

Ähnliche Java Themen

Neue Themen


Oben