Rubrik: Variablen/Strings · Algorithmen/Mathematik | VB-Versionen: VB4, VB5, VB6 | 30.01.03 |
Zufallszahlen mit bestimmter Wahrschinlichkeit Diese Beispiel zeigt, wie sich Zufallszahlen mit vordefinierter Wahrscheinlichkeit berechnen lassen. | ||
Autor: Dieter Otter | Bewertung: | Views: 23.342 |
www.tools4vb.de | System: Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
In VB wird eine Zufallszahl wie folgt erzeugt:
' Sicherstellen, dass immer eine neue Zufallsfolge ' von Zahlen ermittelt wird Randomize -Timer ' Zufallszahl zwischen 1 und 3 ermitteln Dim nZahl As Integer nZahl = Int(3 * Rnd + 1)
Das funktioniert soweit auch. Was aber, wenn man Zufallszahlen mit bestimmter Wahrscheinlichkeit ermitteln möchte? So soll z.B. die Zahl 1 mit einer Wahrscheinlichkeit von 5% ermittelt werden, die Zahl 2 mit einer Wahrscheinlichkeit von 10% und die Zahl 3 mit einer Wahrscheinlichkeit von 85%.
Hierzu folgende Überlegung: Wenn man eine Zufallszahl im Bereich 1 bis 100 ermittelt, so ist die Wahrscheinlichkeit, dassjede Zahl exakt gleich oft ermittelt wird bei 1.000 Durchläufen annähernd gleich. Je mehr Durchläufe desto besser
Auf unser obiges Beispiel bezogen (Zufallszahl 1-3 mit bestimmter Wahrscheinlichkeit) bedeutet das dann folgendes: Wir ermitteln zunächst eine Zufallszahl von 1 bis 100. Wird eine Zahl < 6 ermittelt, ist das unsere Eins (5%). Wird eine Zahl zwischen 6 und 15 ermittelt, bedeutet das die Zwei (10%), und bei einer Zahl größer 15 (also 16 bis 100) die Drei (85%). Auf diese Weise lassen sich Zufallszahlen mit einer bestimmten Wahrscheinlichkeit berechnen
Starten Sie für das nachfolgende Beispiel ein neues Projekt mit drei TextBoxen (Text1, Text2 und Text3), sowie einen CommandButton (Command1).
Private Sub Command1_Click() Dim i As Integer Dim nZahl As Integer ' Sicherstellen, dass immer eine neue Zufallsfolge ' von Zahlen ermittelt wird Randomize -Timer Text1.Text = "0" Text2.Text = "0" Text3.Text = "0" ' 1.000 Durchläufe Do While i < 1000 i = i + 1 ' Zufallszahl zwischen 1 und 100 nZahl = Int(100 * Rnd + 1) Select Case nZahl Case 1 To 5 ' 5% Text1.Text = CStr(Val(Text1.Text) + 1) Case 6 To 15 ' 10% Text2.Text = CStr(Val(Text2.Text) + 1) Case Else ' 85% Text3.Text = CStr(Val(Text3.Text) + 1) End Select Loop End Sub