Duplikate in Array finden...

Maxxie

Neues Mitglied
Hallo zusammen,
ich sitze hier schon seit Stunden und tüftle daran wie ich dieses Problem lösen könnte, ich komm einfach nicht drauf.

11607
Hier mein bisheriger Code:


Java:
package cleararray1;

import java.util.Arrays;

public class ClearArray1 {

    

    public static void main(String[] args) {

        int[] arr = new int[10];

        for (int i = 0; i <= 9; i++) {

            arr[i] = (int) (Math.random() * 9 + 1);

            System.out.print(arr[i] + "\t");
            
        }
        Arrays.sort(arr);
        //System.out.println(Arrays.toString(arr));
        System.out.print("\n\n");
        for (int i = 1; i < arr.length; i++) {
            if (arr[i] == arr[i - 1]) {
              System.out.print(0 + "\t");
            }
            else {
                
                System.out.print(arr[i] + "\t");
            }
        }

    }

    public static int zufZa(int limit) {
        return (int) (Math.random() * limit);

    }

}

Nachdem die Zahlen sortiert, auf Duplikate geprüft wurden und durch 0 ersetzt wurden bekomme ich trotzdem nicht die richtige Ausgabe.
Bei mir sieht es dann so aus:
11608
Ich glaube ich sitze schon zu lange daran um noch irgendwie den Fehler zu finden.
Bitte um Hilfe
Vielen Dank
 

mihe7

Top Contributor
Du könntest z. B. hergehen und Dein Array gedanklich in zwei Teile teilen: der linke Teil ist derjenige, der garantiert keine Duplikate enthält und der rechte Teil ist der Rest.

Am Anfang besteht der linke Teil nur aus dem ersten Element des Arrays. Dieses ist das aktuelle Element (in Deiner Aufgabe wäre das die 3). Dann durchsucht Du den rechten Teil und ersetzt dabei jedes Element, das mit dem aktuellen Element übereinstimmt mit einer 0. Dann kannst Du den linken Teil um ein Element vergrößern. (d .h. das nächste Element wählen).
 

Javinner

Top Contributor
@Maxxie
Letztendlich ganz einfach. Nimm die erste Zahl und prüfe, ob diese im Array noch einmal vorkommt. Dass die Position der ersten Zahl zum Vergleich von der zu vergleichenden Zahl sich um Eins erhöht, liegt an der Hand. Wenn es zutreffen sollte, dann verfahre nach der Methode und entferne alle Duplikate. Fahre solange fort, bis du am Ende des zu prüfenden Arrays angekommen bist.
Java:
private static int[] removeAllDuplicates(int[] array_to_check)
    {
        int[] array = array_to_check;
        int step;
        int arrayLength = 0;
        while (arrayLength < array.length)
        {
            step = array[arrayLength];
            boolean dNumber = check(step, arrayLength, array);
            if (dNumber)
            {
                removeAllDuplicates(step, arrayLength, array);
            }
            arrayLength++;
        }
        return array;
    }

/** Output */
3, 4, 6, 3, 9, 7, 6, 3, 4, 1
3, 4, 6, 0, 9, 7, 0, 0, 0, 1
 

httpdigest

Top Contributor
Benutzt mehr Streams :D
Java:
import static java.util.stream.IntStream.*;

private static boolean enthält(int[] ints, int idx) {
  return of(ints).limit(idx).anyMatch(v -> v == ints[idx]);
}
public static int[] ersetzeDuplikateDurch0(int[] ints) {
  return range(0, ints.length)
    .map(i -> enthält(ints, i) ? 0 : ints[i])
    .toArray();
}
 

krgewb

Top Contributor
Alternativ kannst du auch mit einem HashSet experimentieren. Ein Set ist eine Menge, wie wir sie aus der Mathematik kennen. Eine Menge enthält keine Duplikate.
 

MoxxiManagarm

Top Contributor

httpdigest

Top Contributor
Japp. Und Erfahrung mit rein funktionalen Programmiersprachen. Da lernt man das "funktionale Vokabular" wie "filter", "map", "flatMap", "dropWhile", "takeWhile", etc.. Diese "Primitive" findet man in jeder funktionalen Programmiersprache. Bei mir war es Haskell. Leider leider leider gibt es in Java kein zip und keine Tupeldatentypen, was funktionale Programmierung in Java immer noch sehr einschränkt. Hierfür kann ich nur allerwärmstens https://github.com/jOOQ/jOOL empfehlen!
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
E Array untereinander auf Duplikate prüfen Java Basics - Anfänger-Themen 8
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
G Java Objekte auf Duplikate testen Java Basics - Anfänger-Themen 4
G Exception und Ausgabe der Duplikate Java Basics - Anfänger-Themen 6
M Liste ohne Duplikate Java Basics - Anfänger-Themen 8
I Input/Output 3 Werte in Datei schreiben, duplikate vermeiden Java Basics - Anfänger-Themen 4
E Listen und Duplikate Java Basics - Anfänger-Themen 2
J Duplikate aus Liste entfernen Java Basics - Anfänger-Themen 16
N Suche Technik um Wert-Duplikate auszuschließen Java Basics - Anfänger-Themen 3
0 Dynamische Datenstruktur ohne Duplikate und mit direkter Elementauswahl Java Basics - Anfänger-Themen 3
M Duplikate finden Java Basics - Anfänger-Themen 5
G Geht das effizienter?: Einlesen > Duplikate entf > Spe Java Basics - Anfänger-Themen 13
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
A Elemente in einem Array Java Basics - Anfänger-Themen 5
A Vorkommende Farben ermittel und als Array zurückgeben Java Basics - Anfänger-Themen 7
AhmadSlack Array Java Basics - Anfänger-Themen 7
Jambolo Kartenhand Array Java Basics - Anfänger-Themen 14
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
krgewb byte-Array, das ein Bild repräsentiert Java Basics - Anfänger-Themen 1
1 Array rekursiv durchlaufen Java Basics - Anfänger-Themen 8
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
EykS 3D Druckdatei basierend auf 3D Array? Java Basics - Anfänger-Themen 3

Ähnliche Java Themen

Neue Themen


Oben