Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   warum 30 und nicht 35?!? (https://www.delphipraxis.net/44794-warum-30-und-nicht-35-a.html)

kkkiwi 24. Apr 2005 21:39


warum 30 und nicht 35?!?
 
Hallo ihr

warum gibt diese Function 30 aus, und nicht 35!?



Delphi-Quellcode:
function lies_zahl(z:integer):integer;
begin
if z>1 then
begin lies_zahl:= lies_zahl(z-1)+z*z; end
else lies_zahl:=1;
end;

procdure TForm1.Button1click(sender: TObject);
begin
edit1.text:=inttostr(Lies_zahl(4));
end;
[edit=Christian Seehase]Delphi-Tags gesetzt. Bitte künftig selber machen. Danke. Mfg, Christian Seehase[/edit]

Niels 24. Apr 2005 21:45

Re: warum 30 und nicht 35?!?
 
weil 1 + 4 + 9 + 16 = 30

MfG Niels

tommie-lie 24. Apr 2005 21:47

Re: warum 30 und nicht 35?!?
 
Erster Aufruf: lies_zahl(3)+4*4 = lies_zahl(3) + 16
Zweiter Aufruf: lies_zahl(2) + 9
Dritte Aufruf: lies_zahl(1) + 4
Vierter Aufruf: 1
Ergebnis: 1 + 4 + 9 + 16 = 30

kkkiwi 24. Apr 2005 21:54

Re: warum 30 und nicht 35?!?
 
warum rechne ich das Lies_zahl (z-1) nicht jedes mal noch dazu....
also 3 +4*4?

Niels 24. Apr 2005 21:57

Re: warum 30 und nicht 35?!?
 
lieszahl(4-1) + 4*4 = lieszahl(3-1) + 3*3 + 4*4 = lieszahl(2-1) + 2*2 + 3*3 + 4*4 = 1 + 2*2 + 3*3 + 4*4 = 30

mfg niels

malo 24. Apr 2005 22:01

Re: warum 30 und nicht 35?!?
 
Das "if z > 1" kannst du auch umgehen, indem du den Integer-Parameter durch einen Cardinal-Parameter ersetzt :zwinker:

kkkiwi 24. Apr 2005 22:05

Re: warum 30 und nicht 35?!?
 
also erst mal danke ;)

ich glaub das ich gard ziemlich auf dem schlauch steh *sorry*

aber warum

gilt jedes mal:
lieszahl:(4-1) + 4*4 = lieszahl(3-1) + 3*3 + 4*4 usw...

leddl 24. Apr 2005 22:08

Re: warum 30 und nicht 35?!?
 
Sowas nennt sich Rekursion.
[Edit]
Damit ist gemeint, daß eine Funktion sich selbst immer wieder mit veränderten Parametern aufruft, um so schlußendlich zu einem Ergebnis zu kommen. In deinem Fall nimmt halt die Zahl immer ab, bis sie 1 ist. Addiert wird dann immer das Ergebnis des nächsten Funtkionsaufrufes. Da dort aber wieder die Funktion aufgerufen wird, wird erst dieser Aufruf verarbeitet und das Ergebnis addiert, usw....
[/Edit]

Was du meinst, könntest du so lösen:
Delphi-Quellcode:
function lies_zahl(z:integer):integer;
var i : Integer;
begin
  Result := 1;
  for i := z DownTo 2 Do
    Result := Result + (z-1) + z*z;
end;
PS: Benutz das nächste mal die [delphi]-Tags für den Quelltext! Sieht einfach besser aus! ;)

kkkiwi 24. Apr 2005 22:17

Re: warum 30 und nicht 35?!?
 
werd ich machen ;)


--> dann hätte ich das selbe programm aber nur anderst geschrieben?, oder!?

also bei diesen rekursions programmen, rufe ich immer wieder meine zahl auf, subtrahiere in dem fall -1 und behalte alle rechnungen von vorher bei, und addier sie dann alle zusammen, und des wars dann?!?

omata 24. Apr 2005 22:20

Re: warum 30 und nicht 35?!?
 
Moin,

und ich versuche mich auch nochmal dran...

Es gilt: Punkt vor Strichrechnung

1. Aufruf: (3) + 4 * 4
2. Aufruf: (2) + 3 * 3
3. Aufruf: (1) + 2 * 2

Beim Zurücklaufen wird dann gerechnet...

Delphi-Quellcode:
Aufruf 3: 1 + 2 * 2 = 5
            ____________|
           |           
Aufruf 2: 5 + 3 * 3 = 14
            ____________|
           |
Aufruf 1: 14 + 4 * 4 = 30
            ____________|
           |
        Ergebnis: 30
MfG
Thorsten


Alle Zeitangaben in WEZ +1. Es ist jetzt 20:36 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