AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Sieb des Eratosthenes

Ein Thema von Foxgrove · begonnen am 23. Dez 2005 · letzter Beitrag vom 23. Dez 2005
Antwort Antwort
Foxgrove

Registriert seit: 10. Sep 2005
Ort: Schwäbisch Gmünd
20 Beiträge
 
Delphi 3 Standard
 
#1

Sieb des Eratosthenes

  Alt 23. Dez 2005, 18:38
Hallo,

eigentlich ist es ganz einfach a b e r im Detail
schlage ich mich seit 2 Tagen damit herum:

Ein ganz bekanntes Programm in VBASIC ermittelt alle Primzahlen bis zu einem
eingegebenen Wert über 2 gleiche / parallele Listen (Vektoren, Feldvariable)
Man nennt es "Das Sieb des Eratosthenes".

Die erste Liste übernimmt alle Zahlen bis zum gesuchten Wert
Die andere Liste genausoviele Elemente, wird mit NULLEN aufgefüllt.

Dann geht eine Schleife (die äußere) von 2 bis Quadratwurzel aus dem Endwert ( also 7 wenn Primzahlen bis 50 gesucht würden!)
Die innere Schleife beginnt/wandert mit dem Kontrollwert der äußeren Schleife und geht durch bis zum Endwert a b e r in Schrittweite äußere Schleife
Wenn die Zahl im Zahlenvektor ohne Rest teilbar ist, dann ist es keine Primzahl und im 0-er Vektor wir dann die 0 auf 1 gesetzt.

Auswertung: 1 2 3 sind immer Primzahlen und man beginnt eine 3. Schleife bei 3.
Wenn im 0-er Vektor noch eine 0 ist (überlebt hat), dann ist dies eine Primzahl.


Der CODE, entschuldigt es es BASIC:

....

....
mBis = VAL(txtBis.Text) ....... mBis := StrToInt(BisEdit.Text);
For mI = 1 to mBis
mVek(mI) = mI Vektoren präparieren
mVak(mI) = 0
Next mI

For mI = 2 to SQR(mBis) ..... Schleife von 2 bis Wurzel aus Endwert
If mVak(mI) = 1 then EXIT FOR .. Falls die Zahl schon erkannt ist, gleich weiter ...

For mY = mI to mBis STEP mI von 2 bis 50 aber in 2-er Schritten, dann 3-er , dann 5-er, ...

if mVek(mY)/mY = INT(mVek(mY)/mY) then MOD ginge ja auch
mVak(mI) = 1 .... war teilbar, keine Primzahl
end if
Next mY
Next mI

.....
Ausgabe der Primzahlen:
1 2 3 immer
For mI = 3 to mBis
if mVak(mI) = 0 then lstBox.AddItem Str$(mI)
Next mI

.......................................

An der Schrittweite der inneren Schleife werde ich meinen Verstand noch verlieren, es g e h t nicht in Delphi
Man muss schon routiniert mit While Until Schleifen umgehen können, nehme ich an?


Wie geht es?
Darf man VBASIC Code hier veröffentlichen?
Habe ich gegen etwas verstoßen, Etikette, Rules, Gesetze oder Standards ..

Gruß Foxgrove
  Mit Zitat antworten Zitat
Benutzerbild von Khabarakh
Khabarakh

Registriert seit: 18. Aug 2004
Ort: Brackenheim VS08 Pro
2.876 Beiträge
 
#2

Re: Sieb des Eratosthenes

  Alt 23. Dez 2005, 19:05
Zitat von Foxgrove:
Man muss schon routiniert mit While Until Schleifen umgehen können, nehme ich an?
So schlimm ist es nun auch wieder nicht .
Delphi-Quellcode:
i := Start;
while i <= Stop do
begin
  DoSomethingWith(i);

  Inc(i, Step);
end;
Zitat:
Darf man VBASIC Code hier veröffentlichen?
Nur wenn man ihn artig in [code]-Tags setzt .
Sebastian
Moderator in der EE
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#3

Re: Sieb des Eratosthenes

  Alt 23. Dez 2005, 19:41
Hallo Foxgrove,

die innere Schleife ist eigentlich nicht so sehr problematisch - man darf dabei nur nicht ständig in BASIC denken. Ich habe mich bemüht möglichst nah an deiner Vorgabe dran zu bleiben, aber das zweite Array war mir dann doch zu viel des Guten.

Delphi-Quellcode:
function Sieve(iMax: integer): TIntegerDynArray;
var
  i, iStep, iRoot: integer;
begin
  iRoot := Round(Sqrt(iMax));
  SetLength(Result, iMax);
  for i := 0 to Pred(iMax) do // sieve init
    Result[i] := Succ(i);
  for iStep := 2 to iRoot do
    for i := 2 to iMax div iStep do
      if Result[Pred(i * iStep)] mod iStep = 0 then
        Result[Pred(i * iStep)] := 0; // mark non-prime
  iMax := 3; // first non-prime index
  for i := Succ(iMax) to High(Result) do
    if Result[i] > 0 then
    begin
      Result[iMax] := Result[i]; // pack array
      Inc(iMax);
    end;
  SetLength(Result, iMax); // adjust size
end;
Weihnachtsgrüße vom marabu
  Mit Zitat antworten Zitat
Foxgrove

Registriert seit: 10. Sep 2005
Ort: Schwäbisch Gmünd
20 Beiträge
 
Delphi 3 Standard
 
#4

Re: Sieb des Eratosthenes

  Alt 23. Dez 2005, 23:33
Nun ist es geschafft.
Problem gelöst...

Foxgrove
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:47 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz