Hilfe, doppelte Zufallszahlen

Lyd

Neues Mitglied
Guten Abend,

ich wollte ien Programm schreiben dasein Array mit Zufallszahlen (die nicht doppelt vorkommen dürfen)füllt. Ich weiß nicht wo der Fehler steckt?
Es kommen immernoch doppelte Zahölen raus.

Java:
	public static void Nummern (int N){
		
		int [] a = new int [N];
		
		for (int i = 0; i<N; i++){
			a[i] = (int)((Math.random()*N)+1);
			for (int j = 0; j< N; j++){
		if (a[i]==a[j] && i!= j){
			a[i]=(int)((Math.random()*N)+1);
			j = 0;
			System.out.print(a[i]);
			}
		}
		}
		
	}
 

Haave

Top Contributor
Naja, wenn ich mal umgangssprachlich zusammenfassen darf, was dein Code macht:
"Hey Math.random(), gib mir mal ne Zufallszahl!" "Okay, hier eine 8 für dich." "Hmm, eine 8 hab ich aber schon. Gib mir ne neue Zahl." "Okay, hier hast du eine 8." "Gut, das passt!"

Was ich damit sagen will: Du prüfst nur einmal, ob die Zahl doppelt ist, und lässt dann eine neue generieren. Nach dem zweiten Generieren wird einfach nur noch abgenickt und die Zahl übernommen, auch wenn zufällig die gleiche Zahl nochmal generiert wurde.
 
J

jDennis79

Gast
Wofür ist die zweite for-Schleife? Ihr Sinn erschließt sich mir gerade nicht wirklich, und ich vermute mal ganz stark, dass da auch der Fehler liegt.
 

Murray

Top Contributor
Die zweite Schleife soll das machen, was Haave vermisst, nämlich prüfen, ob der Zufallswert schon irgendwo im Array an einer anderen Stelle auftaucht. Prinzipiell kann das so auch klappen, aber
1. j muss auf -1 gesetzt werden und nicht auf 0, weil das j++ vor dem nächsten Durchlauf ausgeführt wird (und man will wieder ganz von vorn prüfen)
2. sollte die Ausgabe der Zufallszahl erst am Ende der äußeren Schleife passieren.
 
Zuletzt bearbeitet:

timbeau

Gesperrter Benutzer
Ich würde ne eigene Methode schreiben, die Zufallsvariablen ausgibt und die du solange aufrufst bis sie dir eine passende zurückliefert.
 

Murray

Top Contributor
Ein Problem bei diesem Ansatz ist, dass es gerade bei der Verteilung der letzten Zahlen jede Menge Fehlversuche gibt. So gibt es für die letzte Ziffer ja nur noch eine Möglichkeit; trotzdem wird "geraten", bis man zufällig die eine erwischt. Mit der Anzahl der Zahlen steigt auch die Wahrscheinlichkeit, dass die Laufzeit gegen unendlich geht.
Ein besseres Laufzeitverhalten könnte man bekommen, indem man das Array einfach fortlaufend mit den zu verteilenden Zahlen füllt (dann kann es keine doppelten geben) und dann eine feste Anzahl von Vertauschungen macht, indem man z.B zwei Indizes per Random ermittelt und dann die entsprechenden Werte vertauscht.
Man kann zum Vertauschen natürlich auch Collections.shuffleverwenden, aber das ist bei Hausaufgaben vielleicht nicht immer zulässig.
 

faetzminator

Gesperrter Benutzer
Man könnte meinen, dass mir langweilig wär... :D Sogar noch mit einer dritten Lösung...:
Java:
public static List<Integer> getRandomNumbers(int n, int max) {
    if (max < n) {
        throw new IllegalArgumentException("max < n");
    }
    List<Integer> list;
    if (max == n) {
        list = getData(n);
    } else if (max <= n * 2) {
        list = getSmallMaxData(n, max);
    } else {
        list = getBigMaxData(n, max);
    }
    Collections.shuffle(list);
    return list;
}

protected static List<Integer> getData(int n) {
    List<Integer> list = new ArrayList<Integer>(n);
    for (int i = 0; i < n; i++) {
        list.add(i);
    }
    return list;
}

protected static List<Integer> getBigMaxData(int n, int max) {
    Set<Integer> set = new HashSet<Integer>();
    while (set.size() < n) {
        set.add((int) (Math.random() * max));
    }
    return new ArrayList<Integer>(set);
}

protected static List<Integer> getSmallMaxData(int n, int max) {
    List<Integer> list = getData(max);
    while (list.size() > n) {
        list.remove((int) (Math.random() * list.size()));
    }
    return list;
}
 

timbeau

Gesperrter Benutzer
Das hat mich jetzt mal interessiert und ich hab ein wenig getestet und deine Methode mit meiner verglichen.

Ich selber verwende diesen Code:

Java:
static HashSet<Integer> getRandomNumbersHash(int randomCounter, int maxNumber) {
        HashSet<Integer> hs = new HashSet<Integer>();
        SecureRandom secureR = new SecureRandom();
        if(maxNumber < randomCounter){
            throw new IllegalArgumentException("max < n");
        }
        while(hs.size() < randomCounter){
            hs.add(secureR.nextInt(maxNumber));
        }
        return hs;
    }

Dann hab ich ne kurze Testklasse geschrieben und verschiedene Größen ausgewählt.
Bei > ca. 50.000 Zahlen verweigert die List-Methode ihren Dienst bei mir.
Ich habe allerdings den Zahlenraum der Zufallszahlen immer auf Anzahl * 2 gesetzt. Eventuell ist das ausschlaggebend.

Ausgabe:
testHashsetBig() mit Anzahl = 500000
Dauer ca.: 1 Sek bzw. 1928 Millisekunden.
XXXXXXXXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXXXXXXXX


testHashsetBig() mit Anzahl = 50000
Dauer ca.: 0 Sek bzw. 237 Millisekunden.
testListBig() mit Anzahl = 50000
Dauer ca.: 2 Sek bzw. 2865 Millisekunden.


testHashsetMedium() mit Anzahl = 10000
Dauer ca.: 0 Sek bzw. 15 Millisekunden.
testListMedium() mit Anzahl = 10000
Dauer ca.: 0 Sek bzw. 159 Millisekunden.


testHashsetSmall() mit Anzahl = 100
Dauer ca.: 0 Sek bzw. 0 Millisekunden.
testListSmall() mit Anzahl = 100
Dauer ca.: 0 Sek bzw. 1 Millisekunden.
 
Zuletzt bearbeitet:

timbeau

Gesperrter Benutzer
Jo, stimmt :D

0x7F800000´s Lösung ist ja hardcore (Hes a robot:eek:)

Die letzte Lösung erscheint mir mit ähnlichen Problemen behaftet wie meine, bei zu kleiner Differenz zwischen Größe des Sets und Raum der Zufallszahlen. Bei dieser wird zum Ende hin sehr häufig die Zufallszahl inkrementiert um zu passen odeR?
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
E Hilfe bei rekursiver Funktion Java Basics - Anfänger-Themen 3
H pdf stempel - Hilfe erbeten Java Basics - Anfänger-Themen 6
KogoroMori21 Wann ist der richtige Zeitpunkt, um sich Hilfe zu suchen? (Bin Informatik-Student) Java Basics - Anfänger-Themen 10
A Hilfe beim Lesen von Pfaden und Systemvariablen Java Basics - Anfänger-Themen 3
F RegEx Hilfe Java Basics - Anfänger-Themen 5
S Hilfe bei Endlosschleife Java Basics - Anfänger-Themen 2
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
U Ich bräuchte Hilfe Java Basics - Anfänger-Themen 1
Say abstract class und Objekt erzeugen - Dringend Hilfe Java Basics - Anfänger-Themen 10
Justin4687 Benötige Hilfe bei folgender Aufgabe Java Basics - Anfänger-Themen 2
aero043 Hilfe bei BlueJ Hausübung Java Basics - Anfänger-Themen 27
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
P Hilfe gesucht Java Basics - Anfänger-Themen 11
D Hilfe bei Calculator Test Java Basics - Anfänger-Themen 15
R Hilfe bei Aufgabe Java Basics - Anfänger-Themen 4
Zentriks Hilfe zu Sieb des Eratosthenes ohne boolean Java Basics - Anfänger-Themen 5
R Java Bücher hilfe Java Basics - Anfänger-Themen 9
U HILFE! - per ActionListener Felder enablen....... Java Basics - Anfänger-Themen 5
I Scheduling: "Quartz" verwenden, Hilfe bei Umstellung Java Basics - Anfänger-Themen 3
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
L Hilfe! Liste mit Items werden ausgegeben aber nicht in zufälliger Reihenfolge Java Basics - Anfänger-Themen 6
Ekooekoo Hilfe spiel Java Basics - Anfänger-Themen 5
SpiritsHuner Hilfe!! Java Basics - Anfänger-Themen 16
Lacotto Java Kurs Aufgaben Hilfe Java Basics - Anfänger-Themen 14
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
M HILFE JPanel - Graphics Java Basics - Anfänger-Themen 1
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
X Hilfe beim Übertragen in eine For-Schleife Java Basics - Anfänger-Themen 1
Neuling47 Denkfehler? Hilfe Java Basics - Anfänger-Themen 11
S Hilfe bei Umänderung von Java Code Java Basics - Anfänger-Themen 16
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
X Erste Schritte Hilfe bei einem kleinen Spiel. Java Basics - Anfänger-Themen 19
D Bitte um Hilfe muss es schnellstmöglich erledigen Java Basics - Anfänger-Themen 15
L Hilfe bei RegEx Java Basics - Anfänger-Themen 4
I Bitte um Hilfe zu unterstehenden Code Java Basics - Anfänger-Themen 6
B Brauche Hilfe zu einem Code Java Basics - Anfänger-Themen 5
Neuling47 bräuchte dringend hilfe Java Basics - Anfänger-Themen 6
D Bräuchte Hilfe im Bezug zum printarray() Java Basics - Anfänger-Themen 4
M Bitte um Hilfe bei 2DArrays Java Basics - Anfänger-Themen 8
HeiTim Array hilfe Java Basics - Anfänger-Themen 14
M LCD-Ziffern-Hilfe Java Basics - Anfänger-Themen 6
özkan hilfe!! Java Basics - Anfänger-Themen 4
C Hilfe bei einem Anfängerprojekt Java Basics - Anfänger-Themen 25
D Abrechnung bitte um hilfe Java Basics - Anfänger-Themen 25
J Brauche Hilfe bei for-each Aufgabe Java Basics - Anfänger-Themen 1
D Zahlentabelle Anfänger braucht Hilfe Java Basics - Anfänger-Themen 1
HeiTim Brauche Hilfe soll ein nummeriertes Feld ausgeben lassen Java Basics - Anfänger-Themen 17
S Interaktive Abfrage, Hilfe mit Schleifen! Java Basics - Anfänger-Themen 6
N Hilfe bei der Installation Java Basics - Anfänger-Themen 2
J Brauche Hilfe bei Aufgabe Java Basics - Anfänger-Themen 4
S Hilfe bei Programmierung einer Hotelabrechnung Java Basics - Anfänger-Themen 5
enjoykimii Strukturierte Programmierung Hilfe Java Basics - Anfänger-Themen 29
H Bräuchte hilfe Java Basics - Anfänger-Themen 3
D Snake-Spiel ähnliche Aufgabe Hilfe Java Basics - Anfänger-Themen 3
H Brauche Hilfe Java Basics - Anfänger-Themen 2
D Dijkstra Algorithmus Hilfe!! Java Basics - Anfänger-Themen 9
H Hilfe Java Basics - Anfänger-Themen 6
H Brauche hilfe Java Basics - Anfänger-Themen 3
M Hilfe - Array Aufgabe Java Basics - Anfänger-Themen 8
R Schulaufgabe, Bruache Hilfe mit non-static Methoden Java Basics - Anfänger-Themen 2
kevkev Hilfe bei Schiffe versenken Java Basics - Anfänger-Themen 5
FelixxF Erste Schritte Hilfe bei Fußball Manager Java Basics - Anfänger-Themen 2
C Brauche Hilfe beim Schreiben eines Programmes :/ Java Basics - Anfänger-Themen 1
C Brauche Hilfe um ein Programm zu schreiben Java Basics - Anfänger-Themen 8
josfe1234 Hilfe access denied ("java.io.FilePermission" " " "read") Java Basics - Anfänger-Themen 12
Vivien Hilfe bei Type Conversion Java Basics - Anfänger-Themen 3
Leo0909 Ich brauche Hilfe bei dieser Aufgabe Java Basics - Anfänger-Themen 2
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
J Doppelt verkette Liste ich bitte um Hilfe Java Basics - Anfänger-Themen 4
N Laufzeitberechnung - dringende Hilfe! Java Basics - Anfänger-Themen 1
G Java Hilfe Java Basics - Anfänger-Themen 3
J Java List, Bitte um Hilfe Java Basics - Anfänger-Themen 15
J Java List, bitte um Hilfe Java Basics - Anfänger-Themen 3
U anfänger braucht hilfe . wir konnten die aufgaben nicht beantworten Java Basics - Anfänger-Themen 5
A Schleifen, Hilfe! Java Basics - Anfänger-Themen 6
LeonDerStudent Hilfe bei Uniprojekt Java Basics - Anfänger-Themen 2
H Brauche Hilfe in Java Eclipse Programmieraufgabe Neuling Java Basics - Anfänger-Themen 3
B Hilfe bei Map Liste erstellen Java Basics - Anfänger-Themen 10
Kapfski Was habe ich falsch gemacht? Hilfe! Java Basics - Anfänger-Themen 17
R Java (Eclipse) "Lagerverwaltung" HILFE Java Basics - Anfänger-Themen 13
M Bräuchte Hilfe bei diesen Methoden Java Basics - Anfänger-Themen 4
dieter000 Aufgabe Hilfe Java Basics - Anfänger-Themen 18
Gaudimagspam Dringend Java Hilfe benötigt Java Basics - Anfänger-Themen 19
jonathanpizza Hilfe bei einer Übungsaufgabe Java Basics - Anfänger-Themen 6
dieter000 Hilfe bei dem Beispiel, wie gehe ich sowas am besten an? Java Basics - Anfänger-Themen 32
jonathanpizza Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
Q Hilfe auf Aufgabe(Matrixmultiplikation) Java Basics - Anfänger-Themen 1
jonathanpizza Hilfe bei der Aufgabe Java Basics - Anfänger-Themen 19
pry bitte Hilfe beim Kreditrechner objektorientiert Java Basics - Anfänger-Themen 6
R Hilfe bei removeduplicates Java Basics - Anfänger-Themen 5
D Brauche Dringend Hilfe...Prozedur/Funktionsprozedur Ergebnis augeben Java Basics - Anfänger-Themen 11
marcooooo einmal noch schnell hilfe bitte:/ Java Basics - Anfänger-Themen 2
Q Hilfe bei Hausaufgeben Java Basics - Anfänger-Themen 2
J Hilfe beim Label animieren Java Basics - Anfänger-Themen 1
S Hilfe Java Basics - Anfänger-Themen 1
JD_1998 Random Array sortieren mit Hilfe einer Methode Java Basics - Anfänger-Themen 4
Kawastori Hilfe bei Methoden Übung Java Basics - Anfänger-Themen 6
Chabub Hilfe bei Stacks und Queue Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben