Werte im Vector in zufällige Reihenfolge bringen

CodeIt

Aktives Mitglied
Hallo,

ich möchte gerne den Inhalt eines Vectors in zufälliger Reihenfolge anordnen.

Bisher habe ich folgende Möglichkeiten gefunden:

Code:
Vector<Integer> vector = new Vector<>();
vector.add(1);
vector.add(2);
vector.add(3);
vector.add(4);
vector.add(5);

Random random = new Random();
Vector<Integer> vector2 = new Vector<>();
while(vector.size() > 0){
        int index = random.nextInt(vector.size());
        int wert = vector.elementAt(index);
        vector.removeElementAt(index);
        vector2.add(wert);
}

und

Code:
Vector<Integer> vector = new Vector<>();
vector.add(1);
vector.add(2);
vector.add(3);
vector.add(4);
vector.add(5);

Collections.shuffle(vector);

Die zweite Version finde ich natürlich wirklich einfacher, darüberhinaus fand ich noch die Möglichkeit
Code:
SecureRandom secRand = new SecureRandom();
Collections.shuffle(vector, secRand);

Welche Möglichkeit bewirkt denn nun die zufälligste Reihenfolge der Werte?

Hat vielleicht noch jemand einen besseren Vorschlag?

für jeden Tipp wäre ich sehr dankbar
 

Java4win

Aktives Mitglied
meinst du etwas in diese Richtung ?
Java:
int maxElements = 5;
    Vector<Integer> vector = new Vector<Integer>();
    while(vector.size() < maxElements){
        vector.add((int)(Math.random()*5)+1);
    }
 

krgewb

Top Contributor
Es gibt Pseudozufallszahlen in unterschiedlichster Qualität. Möchtest du wissen, wie man die mit der höchsten Qualität erzeugt?
 

CodeIt

Aktives Mitglied
Vielen Dank für die Antworten.
Der Vector enthält bereits die Werte, diese enthaltenen Werte
sollen in eine zufällige Reihenfolge gebracht werden.
Ich frage mich ob es hier besser ist die Werte zufällig einzeln
aus dem Vector zu entnehmen und diese dann in einem anderen
Vector zu speichern oder ist die Anwendung der shuffle-Methode
besser. Was würde mehr einer zufälligen Anordnung entsprechen?
Dann gibt es ja auch noch SecureRandom, welche man zusätzlich
als Parameter in der shuffle-Methode anwenden kann.
Wenn man z.B. einen Vector mit ca. 300 Werten hat, welche
der o.g. Versionen würdet Ihr nehmen? Oder kann mir jemand
eine bessere Methode empfehlen?

Vielen Dank im voraus
 

JStein52

Top Contributor
Zitat: ... sind die Zahlen nicht wirklich zufällig, sondern gehorchen einem mathematischen Verfahren. Kryptografisch bessere Zufallszahlen liefert die Klasse java.security.SecureRandom, die eine Unterklasse von Random ist.

Also würde ich dir die SecureRandom-Variante empfehlen.
 

mrBrown

Super-Moderator
Mitarbeiter
Oder kann mir jemand
eine bessere Methode empfehlen?

Collections.shuffle ohne SecureRandom ist in den meisten Fällen ausreichend. Selber implementieren ist überflüssig, und die Variante mit SecureRandom braucht man in den wenigsten Fällen.

BTW: rein aus Interesse, warum Vector?

Also würde ich dir die SecureRandom-Variante empfehlen.

In den wenigsten Fällen muss das ganze kryptografisch sicher sein ;)

SecureRandom ist z.B. *deutlich* langsamer, und beeinträchtigt uU auch alle anderen Programme, die wirklich sichere Zufallszahlen brauchen.
 
X

Xyz1

Gast
bewirkt denn nun die zufälligste Reihenfolge der Werte?

Diese:
Java:
    public static void main(String[] args) {
        Vector<String> aVector = new Vector<>(); // (Obsolete Collection)
        aVector.add("Hallo");
        aVector.add("neues");
        aVector.add("jahr");

        shuff(aVector);

        System.out.println(aVector);
    }

    private static <T> void shuff(Vector<T> vector1) {
        Random random = new Random();
        Vector<T> vector2 = new Vector<>();
        for (int i = vector1.size() - 1; i >= 0; i--) {
            vector2.insertElementAt(vector1.remove(i), random.nextInt(vector2.size() + 1));
        }
        vector1.addAll(vector2);

        // Geh nochmal auf nummer Sicher:
        // Collections.shuffle(vector1);
    }

shuff-Methode und Collections.shuffle sind gleichgut. SecureRandom bewirkt keine Verbesserung.

Frohes Neues!
 

CodeIt

Aktives Mitglied
Vielen Dank und ein gutes neues Jahr.
Der Code soll nicht für irgendeine Authentifizierung oder
Verschüsselung verwendet werden.
Er soll lediglich die Werte im Vektor zufällig anordnen.
Ich bin mir nur unsicher bezüglich der Zufälligkeit, wenn ich
collections.shuffle(vector) anwende oder wenn ich eben aus
dem Vektor zufällig, mit Random, die Werte entnehme und
diese in einem neuen Vektor speichere, so wie in meiner ersten
oben genannten Version. Aber wenn das stimmt, dass
collections.shuffle den Random-Algorithmus als Default anwendet,
dann dürfte das doch keinen großen Unterschied mehr bezüglich
des Zufalls machen oder?


Collections.shuffle ohne SecureRandom ist in den meisten Fällen ausreichend. Selber implementieren ist überflüssig, und die Variante mit SecureRandom braucht man in den wenigsten Fällen.

BTW: rein aus Interesse, warum Vector?

Die Werte werden ursprünglich aus einem Array entnommen, in
welchem die Reihenfolge der Werte nicht verändert werden soll.
Deshalb entschied ich mich für einen Vector, aus welchem dann die
zufällig angeordneten Werte nacheinander entnommen werden.
 

mrBrown

Super-Moderator
Mitarbeiter
Vielen Dank und ein gutes neues Jahr.
Der Code soll nicht für irgendeine Authentifizierung oder
Verschüsselung verwendet werden.
Er soll lediglich die Werte im Vektor zufällig anordnen.
Ich bin mir nur unsicher bezüglich der Zufälligkeit, wenn ich
collections.shuffle(vector) anwende oder wenn ich eben aus
dem Vektor zufällig, mit Random, die Werte entnehme und
diese in einem neuen Vektor speichere, so wie in meiner ersten
oben genannten Version. Aber wenn das stimmt, dass
collections.shuffle den Random-Algorithmus als Default anwendet,
dann dürfte das doch keinen großen Unterschied mehr bezüglich
des Zufalls machen oder?
Nein, macht es nicht.

Bei sowas empfiehlt es sich immer, die vorhandenen Methoden zu nutzen ;)

Die Werte werden ursprünglich aus einem Array entnommen, in
welchem die Reihenfolge der Werte nicht verändert werden soll.
Deshalb entschied ich mich für einen Vector, aus welchem dann die
zufällig angeordneten Werte nacheinander entnommen werden.
Das Javadoc empfiehlt da ArrayList, wenn du die Threadsicherheit nicht brauchst ;)
 
X

Xyz1

Gast
Er hatte aber danach gefragt.
Ich müsste jetzt selber nachlesen. Es gibt nicht viele Menschen auf der Welt, die verlässliche Aussagen dazu machen können. :p
Aber mal mein Vorgehensmodell: Übersetze den Suchbegriff: ist java collections shuffle gut genug? ins Englische (really random enough?, suitable for a poker algorithm? usw), google danach - und nehme den ersten Treffer nach SO, SE, SE.SE usw
 

mrBrown

Super-Moderator
Mitarbeiter
Aber mit dem Vector funktioniert es auch, was spricht denn gegen
die Verwendung des Vectors?
zB das er deutlich langsamer ist, ist eben die Empfehleung des Javadocs ;)

Ich müsste jetzt selber nachlesen. Es gibt nicht viele Menschen auf der Welt, die verlässliche Aussagen dazu machen können. :p
Aber mal mein Vorgehensmodell: Übersetze den Suchbegriff: ist java collections shuffle gut genug? ins Englische (really random enough?, suitable for a poker algorithm? usw), google danach - und nehme den ersten Treffer nach SO, SE, SE.SE usw
WTF?
Spielst du grad ne Runde Bullshitbingo und brauchtest noch ein paar Begriffe?
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Werte einer Spalte aus DB in einen Vector schreiben Java Basics - Anfänger-Themen 15
K Mehrere Werte in einem Switch Case parallel überprüfen Java Basics - Anfänger-Themen 23
F 2x 16bit Werte zu einem 32bit und dann splitten mit 0xb Java Basics - Anfänger-Themen 1
ptcho Werte/Position nach dem Funktionsaufruf tauschen? Java Basics - Anfänger-Themen 1
K Warum sind Werte in den Feldern ? Java Basics - Anfänger-Themen 2
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
N Einzelne Werte aus einem TreeSet auslesen Java Basics - Anfänger-Themen 2
TeacherMrSSimon Schachspiel, Werte in Figur eintragen klappt nicht Java Basics - Anfänger-Themen 23
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
M Werte in Felder speichern und geordnet ausgeben Java Basics - Anfänger-Themen 8
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
Jambolo Methode, welche die 3 letzten Parameter Werte speichert Java Basics - Anfänger-Themen 20
Chris.089 2 Werte im Array tauschen Java Basics - Anfänger-Themen 6
docmas 2DArray Werte werden nur untereinander ausgegeben Java Basics - Anfänger-Themen 1
M Nur int-Werte erlauben Java Basics - Anfänger-Themen 11
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
M Wie kann eine Methode eine andere Methode um Werte wie z.B. 1 erhöhen? Java Basics - Anfänger-Themen 6
Igig1 Wie lasse ich dir Werte in einem Array zusammenrücken? Java Basics - Anfänger-Themen 4
Igig1 Welche Werte sind als default Werte in einem Array, der als Datentyp eine Klasse hat? Java Basics - Anfänger-Themen 1
J Methoden Positive Werte zählen Java Basics - Anfänger-Themen 3
E Meine JCombobox werte an ohne selectiert zu haben Java Basics - Anfänger-Themen 6
H OOP Werte mit Set verändern Java Basics - Anfänger-Themen 6
W Werte durch Konsole einlesen Java Basics - Anfänger-Themen 10
H Welche Werte bei Objekterzeugung eingeben? Java Basics - Anfänger-Themen 2
M Von einem Menü Methode aus anderer Klasse ausführen, die errechnete Werte in Datei schreibt. Java Basics - Anfänger-Themen 8
sashady ursprüngliche Array-Werte bei erneutem Aufruf? Java Basics - Anfänger-Themen 7
cmn489 Werte beim Funktionsaufruf in ein Feld übertragen(falls dieses leer ist) Java Basics - Anfänger-Themen 1
E In Array Werte einfügen? Java Basics - Anfänger-Themen 5
HighLife Bestimmte Werte aus Array zählen Java Basics - Anfänger-Themen 15
L Methoden ArrayList Werte hinzufügen und löschen Java Basics - Anfänger-Themen 32
J Zufallszahlen generieren und Werte vergleichen Java Basics - Anfänger-Themen 3
M Wie kann ich Werte die in einer While Schleife sind weiter genutzt werden? Java Basics - Anfänger-Themen 7
L Werte von Objekte addieren Java Basics - Anfänger-Themen 14
R Werte und Reihenfolge in 2d Arrays vergleichen Java Basics - Anfänger-Themen 5
I Werte (u.a. Geldbeträge) in Datenbank speichern und Rundungen? Java Basics - Anfänger-Themen 8
eleonori Durchschnitt aller Werte eines Baums berechnen Java Basics - Anfänger-Themen 5
G Array Werte addieren Java Basics - Anfänger-Themen 4
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
C Array-Werte werden gemischt, ohne Logik Java Basics - Anfänger-Themen 2
java3690 Java- liste füllen ud die werte addieren Java Basics - Anfänger-Themen 13
C Zufallszahl + Werte bereich einstellen Java Basics - Anfänger-Themen 2
J Alle Werte eines Strings zusammen addieren Java Basics - Anfänger-Themen 15
L 2 Dimensional Array werte überschreiben Java Basics - Anfänger-Themen 1
K Array alle Werte aufsummieren und ausgeben Java Basics - Anfänger-Themen 6
V Collections int Werte in einer Liste sortieren Java Basics - Anfänger-Themen 23
Rubberduck Combobox-Werte in GUI anzeigen Java Basics - Anfänger-Themen 13
J Neue Werte in ein Array hinzugeben Java Basics - Anfänger-Themen 8
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
A Negative float Werte? Java Basics - Anfänger-Themen 10
Kirby.exe Fehlende Int Werte aus Array mit streams finden Java Basics - Anfänger-Themen 19
Ellachen55 Wie nach häufigste Werte im Array suchen? Java Basics - Anfänger-Themen 2
D Input/Output Input von zwei Koordinaten validieren und anschließend Werte speichern Java Basics - Anfänger-Themen 7
F Variablen Werte einer Klasse überschreiben Java Basics - Anfänger-Themen 4
M Werte ändern sich nicht mehr nach Reset Java Basics - Anfänger-Themen 14
F Character umwandeln als Double Werte Java Basics - Anfänger-Themen 8
B Werte aus einem Unterprogramm in ein Array schreiben Java Basics - Anfänger-Themen 2
L Nur Bestimmte Werte aus einem Array in ein anderes Speichern Java Basics - Anfänger-Themen 11
C Ganzzahlige Werte in Boolean ausgeben und überprüfen ob Primzahl oder nicht, wenn es keine Primzahl ist soll es die Primfaktorzerlegung ausgeben Java Basics - Anfänger-Themen 4
S Werte aufsummieren in java? Java Basics - Anfänger-Themen 5
M Werte des Arrays addieren Java Basics - Anfänger-Themen 5
A Alle true Werte eines boolean Arrays herausfiltern Java Basics - Anfänger-Themen 19
C System.in.read() Boolsche Werte vergleichen Java Basics - Anfänger-Themen 8
M prüfen ob alle array werte gleich sind Java Basics - Anfänger-Themen 27
D Werte aus einem BinärBaum in einem Array speichern Java Basics - Anfänger-Themen 1
R Datenbank-Werte dynamisch ausgeben Java Basics - Anfänger-Themen 19
E Eigenschaften Werte, in einer anderen Klasse, zuweisen Java Basics - Anfänger-Themen 40
H Methoden Nutzung der Werte einer ausgeführten Objektmethode in anderen Objektmethoden Java Basics - Anfänger-Themen 2
O Map Werte Java Basics - Anfänger-Themen 2
dapzoo Compiler-Fehler Beim Werte verteilen in Objektarray NullPointerException Java Basics - Anfänger-Themen 4
L Werte zufällig aus Array zurückgeben Java Basics - Anfänger-Themen 15
B mehrere Werte mit scanner und while schleife einlesen, max berechnen bzw addieren Java Basics - Anfänger-Themen 2
S werte von objekten in schleife verändern Java Basics - Anfänger-Themen 14
R Vererbung werte von einem Objekt aus ein anderes übertragen Java Basics - Anfänger-Themen 7
D Datei auslesen & Werte in Variable speichern Java Basics - Anfänger-Themen 12
N Methoden HashMap interne Werte miteinander vergleichen Java Basics - Anfänger-Themen 7
L Bestimmte Werte eines Arrays ausgeben. Java Basics - Anfänger-Themen 3
Hanschyo String kann nicht Werte von Long annehmen Java Basics - Anfänger-Themen 2
A Sortieren ausgerechneter Werte aus einer TXT Datei Java Basics - Anfänger-Themen 8
S Werte in Klasse übergeben Java Basics - Anfänger-Themen 12
C Auf einzelne Werte aus HashSet zugreifen Java Basics - Anfänger-Themen 10
S Werte in Liste mit Nachfolger vergleichen Java Basics - Anfänger-Themen 5
M Vererbung Konstruktoren mit festen Werte Java Basics - Anfänger-Themen 2
Jinnai4 Werte in Textdatei ändern Java Basics - Anfänger-Themen 2
L Gleiche Werte aus Array aussortieren Java Basics - Anfänger-Themen 5
L Gleiche Werte im Array hochzählen Java Basics - Anfänger-Themen 4
C Matrix-Werte werden nicht wie erwartet ausgegeben Java Basics - Anfänger-Themen 7
V Warum speichert meine String-Variable nummerische Werte? Java Basics - Anfänger-Themen 3
Henri Bestimmte Werte eine XML-Datei ausgeben. Java Basics - Anfänger-Themen 8
N Array-Werte zusammenfassen Java Basics - Anfänger-Themen 20
D Werte AVL-Baum löschen Java Basics - Anfänger-Themen 2
M JComboBox feste double Werte zu ordnen Java Basics - Anfänger-Themen 8
N Collections Werte aus .txt in einer Collection speichern Java Basics - Anfänger-Themen 11
J Array Werte benutzen Java Basics - Anfänger-Themen 16
D Erste Schritte Array Werte an Methode übergeben Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Neue Themen


Oben