Zählen gleiche Werte in Array

Status
Nicht offen für weitere Antworten.

Ganzir

Mitglied
Hallo,

wie kann ich in einem Array die Elemente zählen die identisch sind.

Mal angenommen ich habe folgenden Array:

Code:
		 int[][] zahlen = 
		 {{34,255,255,56},{127,204,11,34},{123,98,127,34},{34,34,127,17}};

Was muss ich nun tun, damit ich die folgende Ausgabe erhalte:

11 = 1 mal
17= 1 mal
34 = 5 mal

usw.

Mit ist die enum-funktion bekannt, jedoch musste ich feststellen, dass ich in enum keine Zahlen verwenden kann.


Greetz
Ganzir
 

hdi

Top Contributor
Kann man sicher schöner machen, ich habs jetzt runtergeschrieben, aber es müsste korrekt sein.
Beachte aber bitte unbedingt folgendes: Das ganze funktioniert jetzt nur, wenn dein gegebenes Array
keine Nullen enthält. Denn Standardmässig ist unser Hilfs-Array mit nullen befüllt. Wenn du Nullen hast,
initialisier das count-Array mit -1 oder sowas. Wenn du auch negative Zahlen hast, und den Wertebereich
nicht kennst, kannst du das so leider nicht mehr lösen...

Code:
public class ArrayZaehler {

	public static void main(String[] args) {

		int[][] zahlen = { { 34, 255, 255 }, { 127, 204, 11, 34 },
				{ 123, 98, 127, 34 }, { 34, 34, 127, 17 } };
		zaehle(zahlen);
	}

	private static void zaehle(int[][] array) {

       // Wir erstellen uns ein 2d-Hifsarray, dass paarweise die Zahl und die Anzahl ihrer Vorkommen enthält.
       // Es kann nicht länger sein als die Anzahl der Elemente im gegebenen Array (dann würde jedes Element
       // genau 1x vorkommen.)

		int maxLen = 0;
		for (int i = 0; i < array.length; i++) {
			maxLen += array[i].length;
		}
		int[][] count = new int[maxLen][2]; // paarweise Zahl<->ihre Anzahl
		int numFilled = 0;

		// diese schleife geht die blöcke durch, also {..}, {..}
		for (int i = 0; i < array.length; i++) {
			// diese schleife durchsucht die einzelnen blöcke
			for (int j = 0; j < array[i].length; j++) {
				// momentanes element speichern:
				int current = array[i][j];
				// nachsehen, ob es das schon im hilfsarray gibt:
				boolean found = false;
				for (int k = 0; k < count.length; k++) {

					if (current == count[k][0]) {
						// Zahl schon gefunden, ihren counter erhöhen:
						count[k][1] = count[k][1] + 1;
						// und aufhören, weiter zu suchen:
						found = true;
						break;
					}

				}
				// schleife wurde komplett durchsucht, und nix gefunden:
				if (!found) {
					// Zahl gibt es noch nicht, einfügen:
					count[numFilled][0] = current;
					count[numFilled][1] = 1;
					numFilled++;
				}
			}
		}

		// Fertig, das kann man jetz formatiert ausgeben:
		for (int i = 0; i < count.length; i++) {
			if (count[i][0] != 0) { // bzw. != dein Initial-Wert
				System.out.println("Zahl " + count[i][0] + " kommt "
						+ count[i][1] + " mal vor.");
			}
		}
	}
}
 

Ganzir

Mitglied
Hallo hdi,

das ist sehr nett was du da geschrieben hast, es funktioniert auch, jedoch bin ich absoluter Anfänger und hatte mir eine etwas plumpere Methode ausgedaucht:

Code:
public static void main (String args[])
	 {   

		 int z_11 = 0;
		 
		 int[][] zahl = 
		 {{34,255,255,56},{127,204,11,34},{123,98,127,34},{34,34,127,17}};
	 
		 
		 for (int i = 0; i < zahl.length; i++)
		 {
			 for (int j = 0; j < zahl[0].length; j++)

				 System.out.print(zahl[i][j] + "\t");
			 System.out.println();
			 int current = zahl[i][j]; //<-  An dieser Stelle sagt er mit er kann j nicht resolven - kannst du mir sagen wieso? bei dir klappt da doch auch int current = array[i][j]; 
			
			 }

		 }
	
	 }
 

Marco13

Top Contributor
Es fehlt noch die { für die innere for-Schleife.

Nochmal eine Lösugn, die man verwenden kann, wenn das ganze nicht ausführungs- sondern Entwicklungszeitritisch ist:
Code:
import java.util.*;

class ArrayCount
{
    public static void main(String args[])
    {
        int[][] a = {{34,255,255,56},{127,204,11,34},{123,98,127,34},{34,34,127,17}};
        count(a);
    }

    private static void count(int a[][])
    {
        Map<Integer, Integer> map = new HashMap<Integer, Integer>();
        for (int i=0; i<a.length; i++)
        {
            for (int j=0; j<a[i].length; j++)
            {
                map.put(a[i][j], map.containsKey(a[i][j])?map.get(a[i][j])+1:1);
            }
        }
        for (Integer k : map.keySet())
        {
            System.out.println(k+": "+map.get(k)+" times");
        }
    }


}
 

hdi

Top Contributor
Jo, und so macht man es schön ;) Ich hatte mir auch erst gedacht ich sollte ne Map nehmen, aber dachte dann das is genauso kompliziert. Diese Zeile:

Code:
map.put(a[i][j], map.containsKey(a[i][j])?map.get(a[i][j])+1:1);

hat es in sich^^ Das so zu machen kommt einem auch nur, wenn man die Map-Methoden im Kopf hat alle xD
 

Marco13

Top Contributor
Naja - erst hatte ich sie als
Code:
if (!map.containsKey(a[i][j]))
{
    map.put(a[i][j], 0);
}
map.put(a[i][j], map.get(a[i][j])+1);
was etwas übersichtlicher ist - optional dann auch
Code:
if (!map.containsKey(a[i][j]))
{
    map.put(a[i][j], 1);
}
else
{
    map.put(a[i][j], map.get(a[i][j])+1);
}
aber ... ich glaube, sie wirkt nur durch die arrayzugriffe so kompliziert:
Code:
map.put(n, map.containsKey(n)?map.get(n)+1:1);
ist doch auch hübsch.... :)
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Gleiche Elemente in Feld zählen Java Basics - Anfänger-Themen 13
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
M Häufigkeit von Wörtern zählen Java Basics - Anfänger-Themen 6
Cassy3 Binäre Bäume Rekursiv durchlaufen und bestimmte Elemente Zählen Java Basics - Anfänger-Themen 6
D spezifische Knoten in einem Baum zählen Java Basics - Anfänger-Themen 9
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
S Java Methodenaufrufe zählen Java Basics - Anfänger-Themen 4
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
S Methoden Methodenaufruf rekursiv zählen Java Basics - Anfänger-Themen 4
J Methoden Positive Werte zählen Java Basics - Anfänger-Themen 3
H Buchstaben zählen Java Basics - Anfänger-Themen 9
Poppigescorn Häufigkeit einer zahl zählen Java Basics - Anfänger-Themen 5
HighLife Bestimmte Werte aus Array zählen Java Basics - Anfänger-Themen 15
O Attribute die Methoden zählen Java Basics - Anfänger-Themen 5
X Game of Life Nachbarn zählen Java Basics - Anfänger-Themen 20
F Java Programm, das kleine Buchstaben in einem String zählen soll und bei großen Buchstaben oder Sonderzeichen abbrechen soll. Java Basics - Anfänger-Themen 5
Z Satz aufteilen und die Wörter zählen (HashMap) Java Basics - Anfänger-Themen 15
S Binärbäume knoten zählen Java Basics - Anfänger-Themen 16
K Counts zählen Java Basics - Anfänger-Themen 23
Kirby.exe Anzahl vorkommender Elemente im Array zählen Java Basics - Anfänger-Themen 9
J Zeichen im String zählen Java Basics - Anfänger-Themen 3
G Binärer Suchbaum Knoten zählen Java Basics - Anfänger-Themen 1
N Zeichen in einem Textfeld zählen und hinterlegen Java Basics - Anfänger-Themen 6
E Knoten eines Baumes unter Bedinung zählen Java Basics - Anfänger-Themen 2
T x Schritte zählen Java Basics - Anfänger-Themen 18
P Schlüsselworte Zählen und Zuweisen von eingelesenen Zahlen Java Basics - Anfänger-Themen 1
A In einem String alle Eigennamen zählen Java Basics - Anfänger-Themen 6
L Baum Knoten zählen Java Basics - Anfänger-Themen 6
B Objekte zählen/ Vererbung/ Kopplung/ Interface/ Abstract Class Java Basics - Anfänger-Themen 5
S Zählen der Zeiger auf Objekte Java Basics - Anfänger-Themen 35
S Zeichen zählen kopierter Text Java Basics - Anfänger-Themen 6
B Array - die Häufigkeit der Zahl zählen Java Basics - Anfänger-Themen 9
L Vorherige Objekte zählen und ausgeben Java Basics - Anfänger-Themen 11
L Diphthonge zählen... Java Basics - Anfänger-Themen 5
O ELOPS Zählen Java Basics - Anfänger-Themen 1
S Rekursives Zählen einer Zahl Java Basics - Anfänger-Themen 8
X Quick Sort - Vergleichsoperationen zählen Java Basics - Anfänger-Themen 0
K alle Vorkommen einer bestimmten Ziffer in einer Zahl zählen Java Basics - Anfänger-Themen 2
B Collections Java Wörter in String zählen und geordnet ausgeben Java Basics - Anfänger-Themen 10
O Großbuchstaben im Satz zählen Java Basics - Anfänger-Themen 6
S zahl hoch und runter zählen per button Java Basics - Anfänger-Themen 25
N Zählen von Rationalen Werten eines Arrays Java Basics - Anfänger-Themen 10
Y for-Schleife zählen Java Basics - Anfänger-Themen 6
K Probleme mit Sortieren und dem Zählen Java Basics - Anfänger-Themen 13
S Vererbung Objekte von Ober - und Unterklassen zählen Java Basics - Anfänger-Themen 3
F SubString in String zählen Java Basics - Anfänger-Themen 3
C Im Array zählen und verändern Java Basics - Anfänger-Themen 5
O Zählen der while-Scheife Java Basics - Anfänger-Themen 3
P bytes aus einem InputStream zählen Java Basics - Anfänger-Themen 2
A Text teilen und Wörter zählen Java Basics - Anfänger-Themen 7
G Erste Schritte Einen Array absuchen und Buchstaben zählen Java Basics - Anfänger-Themen 17
F Problem mit Tabulatoren bei Zeilen zählen einer Textdatei Java Basics - Anfänger-Themen 17
F Textdatei einlesen und Zeilen zählen Java Basics - Anfänger-Themen 10
D Groß/KleinBuchstaben zählen Java Basics - Anfänger-Themen 21
D Buchstabe zählen/mappen Java Basics - Anfänger-Themen 3
S Anzahl unterschiedlicher Elemente zählen Java Basics - Anfänger-Themen 4
M Hilfe bei Zählen von Farben? Java Basics - Anfänger-Themen 7
R Input/Output Tastenschläge einer Taste zählen Java Basics - Anfänger-Themen 14
J Schleifendurchläufe zählen Java Basics - Anfänger-Themen 4
B Zweidimensionales Array Elemente jeder Spalte zählen Java Basics - Anfänger-Themen 9
E Methoden Methodenaufrufe zählen Java Basics - Anfänger-Themen 11
T Leerzeichen zählen mit Rekursion Java Basics - Anfänger-Themen 17
H Programm zum Zählen von Zeichen Java Basics - Anfänger-Themen 5
K Kommandozeile zählen Java Basics - Anfänger-Themen 5
J Bits zusammen zählen Java Basics - Anfänger-Themen 4
P Hashtabelle-Häufigkeit von String zählen Java Basics - Anfänger-Themen 2
J Array; Vorkommen zählen Java Basics - Anfänger-Themen 10
T durchlaufene while-Schleifen zählen Java Basics - Anfänger-Themen 3
P Replace zählen Java Basics - Anfänger-Themen 4
A Methoden Gedanken Anstöße zur Realisierung zweier Ideen (Grafisch Sekunden zählen und Frameaufteilung) Java Basics - Anfänger-Themen 18
E Zeichen von Kommandozeilenparameter zählen Java Basics - Anfänger-Themen 6
L Objekte zählen mehrerer Unterklassen Java Basics - Anfänger-Themen 3
J Buchstaben aus String einzeln Zählen Java Basics - Anfänger-Themen 12
J Enum zählen Java Basics - Anfänger-Themen 8
M Automatisch hoch zählen Java Basics - Anfänger-Themen 8
S Zählen Java Basics - Anfänger-Themen 9
V Arraylist: Zählen welcher String am Häufigsten vorkommt Java Basics - Anfänger-Themen 5
A Erste Schritte Datei einlesen und Buchstaben zählen Java Basics - Anfänger-Themen 13
M Von File lesen Buchstaben lesen und zählen - scheitert an der Eingabe Java Basics - Anfänger-Themen 4
B Zählen bestimmter Zeilen einer .txt Java Basics - Anfänger-Themen 7
A Satzeingabe - Vokale zählen Java Basics - Anfänger-Themen 5
B Input/Output Wörter zählen & sortieren Java Basics - Anfänger-Themen 9
S Buchstaben/Wörter im String zählen Java Basics - Anfänger-Themen 6
K apache poi - Spalten zählen Java Basics - Anfänger-Themen 4
T Methodenaufrufe zählen Java Basics - Anfänger-Themen 24
L Array Sequent Zählen Java Basics - Anfänger-Themen 8
N Bestimmte Zeichen aus Strings zählen Java Basics - Anfänger-Themen 11
C Boolean Wahrheitswert zählen Java Basics - Anfänger-Themen 15
C Vorkommen eines Zeichens zählen Java Basics - Anfänger-Themen 4
D Game of Life - Nachbarn zählen Java Basics - Anfänger-Themen 8
J Buchstaben zählen Java Basics - Anfänger-Themen 17
R buchstaben zählen Java Basics - Anfänger-Themen 8
D Zählen von Umlauten in einem String Java Basics - Anfänger-Themen 4
E Array Inhalte zählen Java Basics - Anfänger-Themen 6
B Strings zählen Java Basics - Anfänger-Themen 15
Z Zeichen Zählen Java Basics - Anfänger-Themen 3
B Files aus Verzeichnis zählen Java Basics - Anfänger-Themen 9
J Wörter in einem string zählen und die anzahl zurückgeben Java Basics - Anfänger-Themen 4
I Zeichen zählen ohne Leerzeichen Java Basics - Anfänger-Themen 3
M Blätter eines Baumes zählen Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben