Ein Array sortieren - dafür gibt es ja bekanntermaßen einen Befehl. Aber ich brauchte für einen bestimmten Zweck immer mal wieder ein Array, dessen Elemente zufällig durchmischt sein sollten. Daraus sind zwei Funktionen entstanden, die folgendermaßen arbeiten: Die Funktion getRndArrayMix erstellt ein Ergebnisarray, dessen Elemente zufällig angeordnet sind. Dabei verwendet sie die Funktion GetRndIndizes, die zunächst nur ein temporäres Feld erzeugt, das als Elemente nur zufällig angeordnete Indizes beinhaltet. Dieses Feld wird dann in der ersten Funktion benutzt, um die Elemente des Ausgangsfeldes ins Ergebnisfeld einzuordnen. 1. Funktion ''' <summary> ''' Erzeugen eines zufälligen Mix der Arrayelemente ''' </summary> ''' <param name="theArray">das zu verarbeitende Array (Source-Feld)</param> Public Function getRndArrayMix(ByVal theArray As Array) As Array ' Feld mit zufällig verteilten Indizes erstellen Dim rndNum() As Integer = GetRndIndizes(theArray.Length) Dim temp(rndNum.Length - 1) As Object ' Temporäres Feld mit den zufällig verteilten Werten ' des Source-Felds erstellen For i As Integer = 0 To theArray.Length - 1 temp.SetValue(theArray(i), rndNum(i)) Next Return temp ' Rückgabe des gemischten Felds End Function 2. Funktion ''' <summary> ''' Erzeugen eines Index-Array mit Zufallszahlen ohne Duplikate ''' </summary> ''' <param name="theArrayLen">Länge des zu mischenden Arrays</param> Public Function GetRndIndizes(ByVal theArrayLen As Integer) As Integer() Dim rndIndizes(theArrayLen - 1) As Integer Dim i, idRnd As Integer ' Initialisieren des Feldes der zufällig verteilten Indizes For i = 0 To theArrayLen - 1 rndIndizes(i) = -1 Next Randomize() ' Einspeichern von Indizes in zufälliger Reihenfolge For i = 0 To theArrayLen - 1 Do ' Zufallszahl im Bereich (0...größter Index des Source-Feldes) erzeugen idRnd = (theArrayLen - 1) * Rnd() ' Ist Zufallszahl schon im Feld der Indizes? If Array.IndexOf(rndIndizes, idRnd) < 0 Then rndIndizes(i) = idRnd Exit Do End If Loop Next Return rndIndizes End Function Aufruf: Dim ergebnisRandomField() as object= getRndArrayMix(sourceArray) Beispiel: Dim sourceArray() = {"Hans", "Michael", "Dieter", "Anton", _ "Felix", "Guido", "Stefan", "Roland", "Günther", "Rainer"} Dim ergebnisRandomField() As Object = getRndArrayMix(sourceArray) ListBox1.DataSource = ergebnisRandomField Dieser Tipp wurde bereits 14.309 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
Neu! sevEingabe 3.0 Einfach stark! Ein einziges Eingabe-Control für alle benötigten Eingabetypen und -formate, inkl. Kalender-, Taschenrechner und Floskelfunktion, mehrspaltige ComboBox mit DB-Anbindung, ImageComboBox u.v.m. Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |