ABOUT Visual Basic Programmieren Programmierung Download Downloads Tips & Tricks Tipps & Tricks Know-How Praxis VB VBA Visual Basic for Applications VBS VBScript Scripting Windows ActiveX COM OLE API ComputerPC Microsoft Office Microsoft Office 97 Office 2000 Access Word Winword Excel Outlook Addins ASP Active Server Pages COMAddIns ActiveX-Controls OCX UserControl UserDocument Komponenten DLL EXE
Diese Seite wurde zuletzt aktualisiert am 29.02.2000

Diese Seite wurde zuletzt aktualisiert am 29.02.2000
Aktuell im ABOUT Visual Basic-MagazinGrundlagenwissen und TechnologienKnow How, Tipps und Tricks rund um Visual BasicActiveX-Komponenten, Controls, Klassen und mehr...AddIns für die Visual Basic-IDE und die VBA-IDEVBA-Programmierung in MS-Office und anderen AnwendungenScripting-Praxis für den Windows Scripting Host und das Scripting-ControlTools, Komponenten und Dienstleistungen des MarktesRessourcen für Programmierer (Bücher, Job-Börse)Dies&Das...

Themen und Stichwörter im ABOUT Visual Basic-Magazin
Code, Beispiele, Komponenten, Tools im Überblick, Shareware, Freeware
Ihre Service-Seite, Termine, Job-Börse
Melden Sie sich an, um in den vollen Genuss des ABOUT Visual Basic-Magazins zu kommen!
Informationen zum ABOUT Visual Basic-Magazin, Kontakt und Impressum

Zurück...

Primfaktoren

Zurück...


Anzeige

(-hg) mailto:hg_primes@aboutvb.de

Mit den folgenden zwei Funktionen können Sie eine Zahl in ihre Primfaktoren zerlegen. Die Funktion PrimesToArray gibt ein Array mit der Untergrenze 1 zurück, die Funktion PrimesToCollection eine Visual Basic-Collection.

Public Function PrimesToArray(ByVal Number As Long) _
 As Variant

  Dim nArray() As Long
  Dim nA As Long
  Dim nB As Long
  Dim nW As Long
  Dim i As Integer
  Dim nIndex As Long
  
  If Number = 0 Then
    Exit Function
  End If
  ReDim nArray(1 To 10)
  nA = Number
  nB = 2
  nW = nA \ 2
  For i = 1 To 10
    nW = (nW + (nA \ nW)) \ 2
  Next 'i
  Do While nA <> 1
    Do While nA Mod nB = 0
      nA = nA \ nB
      nIndex = nIndex + 1
      If UBound(nArray) < nIndex Then
        ReDim Preserve nArray(1 To nIndex + 10)
      End If
      nArray(nIndex) = nB
    Loop
    If nB > nW Then
      nB = nA - 2
    End If
    If nB = 2 Then
      nB = 1
    End If
    nB = nB + 2
  Loop
  ReDim Preserve nArray(1 To nIndex)
  PrimesToArray = nArray
End Function

Die Funktion PrimesToArray zerlegt eine Zahl in ihre Primfaktoren und gibt diese in einem Array zurück

Public Function PrimesToCollection(ByVal Number As Long) _
 As Collection

  Dim nColl As Collection
  Dim nA As Long
  Dim nB As Long
  Dim nW As Long
  Dim i As Integer
  
  If Number = 0 Then
    Exit Function
  End If
  Set nColl = New Collection
  nA = Number
  nB = 2
  nW = nA \ 2
  For i = 1 To 10
    nW = (nW + (nA \ nW)) \ 2
  Next 'i
  Do While nA <> 1
    Do While nA Mod nB = 0
      nA = nA \ nB
      nColl.Add nB
    Loop
    If nB > nW Then
      nB = nA - 2
    End If
    If nB = 2 Then
      nB = 1
    End If
    nB = nB + 2
  Loop
  Set PrimesToCollection = nColl
End Function

Die Funktion PrimesToCollection zerlegt eine Zahl in ihre Primfaktoren und diese in einer Collection zurück


Modul modPrimes (modPrimes.bas - ca. 1,8 KB)


Artikel
Zum Download-Bereich dieses Artikel
Mail an den Autor dieses Artikel

KnowHow
Zur KnowHow-Übersicht

KnowHow-Themen
Themen - Allgemeines
Themen - Entwicklungsumgebung (VB-IDE)
Themen - Forms
Themen - Steuerelemente (Controls)
Themen - Grafik
Themen - Dateien
Themen - UserControls
Themen - Einsteiger-Tipps
Themen - Wussten Sie...?

Übersicht nach Titeln in alphabetischer Reihenfolge
Übersicht nach Erscheinungsdatum

Schnellsuche



Zum Seitenanfang

Copyright © 1999 - 2017 Harald M. Genauck, ip-pro gmbh  /  Impressum

Zum Seitenanfang

Zurück...

Zurück...

Download Internet Explorer