Im Bereich der asymetrischen Verschlüsselung werden häufig die Primfaktoren einer natürlichen Zahl benötigt. Denn jede natürliche Zahl lässt sich durch Primzahlen faktorisieren. Beim folgendem Modul handelt es sich um eine Konsolenapplikation, die dem Benutzer nach einer Zahl fragt. Daraus berechnet das Programm dann die Primfaktoren. Module Module1 Sub Main() Dim zahl As Integer Dim prim As Boolean Dim i As Integer Dim j As Integer Dim k As Integer Dim l As Integer Dim col As New Collection Dim fakt As New Collection Dim primzahlen As ArrayList = ArrayList.Adapter(col) Dim primfaktoren As ArrayList = ArrayList.Adapter(fakt) ' ----------------------------------------------------------- ' Benutzer wird aufgefordert, eine Zahl einzugeben Console.Write("Bitte geben Sie eine Zahl ein: ") zahl = Console.ReadLine ' Alle Primzahlen bis zu der eingegebene Zahl berechnen ' und in das Array primzahlen packen. For i = 2 To zahl prim = True For j = 2 To System.Math.Sqrt(i) If i Mod j = 0 Then prim = False Exit For End If Next If prim = True Then primzahlen.Add(i) Next ' Die eingegebene Zahl wird durch jede Primzahl, beginnend bei 2 dividiert. ' Ist das Ergebnis der Division Mod 0 (ohne Rest), handelt es sich um einen ' Primfaktor und wird dem Array primfaktoren hinzugefügt. ' Danach wird mit dem Ergebnis der Division weitergerechnet For k = 0 To primzahlen.Count - 1 Do While zahl Mod primzahlen(k) = 0 primfaktoren.Add(primzahlen(k)) zahl = zahl / primzahlen(k) ' Wenn das Divisionsergebnis eine Primzahl ist, kann ' die Berechnung beendet werden. If primzahlen.Contains(zahl) Then Exit Do Loop Next For l = 0 To primfaktoren.Count - 1 Console.WriteLine(primfaktoren(l)) Next Console.ReadLine() End Sub End Module Dieser Tipp wurde bereits 10.675 mal aufgerufen.
Anzeige
![]() ![]() ![]() (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren [email protected]! - 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! sevPopUp 2.0 ![]() Dynamische Kontextmenüs! Erstellen Sie mit nur wenigen Zeilen Code Kontextmenüs dynamisch zur Laufzeit. Vordefinierte Styles (XP, Office, OfficeXP, Vista oder Windows 8) erleichtern die Anpassung an die eigenen Anwendung... Tipp des Monats ![]() Dieter Otter PopUp-Menü wird nicht angezeigt :-( In diesem Tipp verraten wir Ihnen, wie Sie Probleme mit PopUp-Menüs umgehen können, wenn diese unter bestimmten Umständen einfach nicht angezeigt werden. sevISDN 1.0 ![]() Überwachung aller eingehender Anrufe! Die DLL erkennt alle über die CAPI-Schnittstelle eingehenden Anrufe und teilt Ihnen sogar mit, aus welchem Ortsbereich der Anruf stammt. Weitere Highlights: Online-Rufident, Erkennung der Anrufbehandlung u.v.m. |
||||||||||||||||
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. |