Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   Gerade Zahl (https://www.delphipraxis.net/171765-gerade-zahl.html)

rüssel 23. Nov 2012 17:25

Gerade Zahl
 
Hallo,
ich wollte aus einem zufallsfeld welches in einem memo ausgegeben wird alle Zahlen löschen die gerade sind.

Leider schaffe ich das nicht.

Mein Ansatz ist das die jeweilige zahl moduliert mit 2 gleich 0 ist.
Leider komm ich nicht dazu dass dieser Vergleich im memo stattfindet und dass diese Zahlen gelöscht werden

Mit freundlichen Grüßen

rüssel

Helmi 23. Nov 2012 17:30

AW: Gerade Zahl
 
wie wärs damit:

Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
  i: Integer;
  n: Integer;

begin
  for i := Pred(Memo1.Lines.Count) downto 0 do
    If TryStrToInt(Memo1.Lines.Strings[i], n) then
      If (n mod 2) = 0 then
        Memo1.Lines.Delete(i);
end;

rüssel 23. Nov 2012 17:34

AW: Gerade Zahl
 
Vielen Vielen Dank :-D :)

himitsu 23. Nov 2012 17:43

AW: Gerade Zahl
 
Delphi-Referenz durchsuchenOdd

[edit]
auf "New" klicken > www.delphipraxis.net/issue-436/

Helmi 23. Nov 2012 17:56

AW: Gerade Zahl
 
Zitat:

Zitat von himitsu (Beitrag 1192664)

Der vollständigkeitshalber:
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
  i: Integer;
  n: Integer;

begin
  for i := Pred(Memo1.Lines.Count) downto 0 do
    If TryStrToInt(Memo1.Lines.Strings[i], n) then
      If not Odd(n) then
        Memo1.Lines.Delete(i);
end;

rüssel 23. Nov 2012 18:06

AW: Gerade Zahl
 
Dankeschön

Also falls es nicht unpassend ist hätte ich noch eine Frage bezüglich des Programms, und zwar
wenn man nur Primzahlen möchte habe ich probiert, das hier anzuhängen, aber es funktioniert nicht,
könntet ihr mir vielleicht einen Ratschlag geben.
Delphi-Quellcode:
var a,i,n:integer;
begin
   a:=1;
   for i := Pred(Memo1.Lines.Count) downto 0 do
    If TryStrToInt(Memo1.Lines.Strings[i], n) then
      If not odd(n) then
        Memo1.Lines.Delete(i);
       If n = 1 then Memo1.Lines.Delete(i);
         if n <> 1 then
          begin
           repeat
            a:=a+1
           until n mod a = 0;
            if n mod a <> 0
            then Memo1.Lines.Delete(i);
          end;
end;
Falls es keine Umstände bereitet köntet ihr mir Pred und TryStrtoint erklären, bitte.

himitsu 23. Nov 2012 18:12

AW: Gerade Zahl
 
Die OH (F1-Taste) kennst du?

Und notfalls gibt es auch noch die Delphi-Referenz, welche auf der Startseite der DP verlinkt ist. (das Ding, womit och da oben das Delphi-Referenz durchsuchenOdd verlinkt hatte)


Du wirst es nicht glauben, aber da steht drin was welcher Befehl macht. :zwinker:

Delphi-Quellcode:
Pred(X) = X - 1
(Tipp: Code sieht als Code formatiert schöner aus und vorallem ist er lesbarer)

Aber ich würde mal vermuten (so richtig erkennen kann man es ja nicht) du hast ein paar BEGIN und END vergessen.
(vorallem bei/nach
Delphi-Quellcode:
If TryStrToInt(Memo1.Lines.Strings[i], n) then
)

Uwe Raabe 23. Nov 2012 18:20

AW: Gerade Zahl
 
Zitat:

Zitat von himitsu (Beitrag 1192664)

Odd ist übrigens wesentlich performanter! Es prüft einfach nur das niederwertigste Bit des Operanden. Daran erkennt man, daß Pascal noch aus Zeiten stammt, in denen Rechenzeit kostbar war.

rüssel 23. Nov 2012 18:23

AW: Gerade Zahl
 
Also vielen Dank für die Informationen.

himitsu 23. Nov 2012 19:09

AW: Gerade Zahl
 
Ein "Problem":
Nach IF-THEN, FOR-DO, WHILE-DO und Co. wird immer nur ein "Befehl" behandelt.
Oder eben ein ganzer Block (BEGIN-END)

Oder man kann auch mehrere IFs via ELSE verbinden.

Delphi-Quellcode:
var
  a, i, n: Integer;
begin
  a := 1;
  for i := Memo1.Lines.Count - 1 downto 0 do // oder eben mit Pred ... was man halt mehr mag
    if TryStrToInt(Memo1.Lines.Strings[i], n) then
      if not Odd(n) then
        Memo1.Lines.Delete(i);
      else if n = 1 then
        Memo1.Lines.Delete(i);
      else // es kann nur noch "if n <> 1 then" sein
        begin
          a := n div 2; // man kann gern auch mit "a := n;" anfangen
          repeat
            Dec(a); // a := a - 1;
          until (n mod a = 0) or (a <= 1); // auch wenn es keine Primzahl ist, soll irgendwann abgebrochen werden
          if a > 1 then // oder "if n mod a <> 0 then" , aber das Andere ist kürzer
            Memo1.Lines.Delete(i);
        end;
end;


Alle Zeitangaben in WEZ +1. Es ist jetzt 12:33 Uhr.
Seite 1 von 2  1 2      

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