AGB  ·  Datenschutz  ·  Impressum  







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

Rekursion - Berechnung von Fakultäten

Ein Thema von Ari · begonnen am 17. Sep 2007 · letzter Beitrag vom 20. Sep 2007
Antwort Antwort
Ari

Registriert seit: 7. Jan 2007
Ort: Wilhelmshaven
37 Beiträge
 
#1

Rekursion - Berechnung von Fakultäten

  Alt 17. Sep 2007, 23:08
Hey ihr,

hab grad nen Problem mit der Rekursion. Sollten Fakultäten auf zwei Wegen berechnen - iterativ (Button1) und rekursiv (Button2):

Delphi-Quellcode:
function fakultaet (a: integer) : integer;
begin
         if a>0 then
         result := a * fakultaet(a-1)
         else result:=1;
end;

procedure TForm1.BitBtn1Click(Sender: TObject);
var text, i, ergebnis : integer;
begin
        text:=StrToInt(Edit1.Text);
        ergebnis:=1;
        for i:=1 to text do begin
             ergebnis:=ergebnis*i;
             Label1.Caption:=IntToStr(ergebnis);
        end;
        if text=0 then Label1.Caption:=IntToStr(1); //(0!=1)
        if text<0 then Label1.Caption:='Bitte geben Sie eine natürliche Zahl ein!'; //text\in N
end;

procedure TForm1.BitBtn2Click(Sender: TObject);
var k : integer;
begin
       k:=fakultaet(StrToInt(Edit1.Text));
       Label1.Caption:=IntToStr(k);
end;
Mein Problem bezieht sich auf die Funktion fakultaet. Und zwar habe ich durch Recherche die Variable "result" gefunden und versuchsweise eingefügt - mysteriöserweise funktioniert es auch, obwohl ich result nirgends bewusst definiert habe (vordefiniert???) und es sonst auch nicht in dieser *.pas-Datei auftaucht.
Nehme ich als Variable irgendetwas anderes, meckert er wieder wegen einer undefinierten Variable - wo soll ich die denn definieren? Definiere ich es so

Delphi-Quellcode:
function fakultaet (a: integer) : integer;
var zwsp : integer;
begin
         if a>0 then
         zwsp := a * fakultaet(a-1)
         else zwsp:=1;
end;
komme ich auch nicht weiter, ich erhalte immer dasselbe Ergebnis 43tausend und ein paar zerquetschte (auch wenn ich zwsp als integer definiere).

Woher kommt nu die vordefinierte "result"-Variable und wie bastel ich das Programm ohne eben diese zusammen`?

Bitte helft mir ^^
Ariane
  Mit Zitat antworten Zitat
Benutzerbild von Matze
Matze
(Co-Admin)

Registriert seit: 7. Jul 2003
Ort: Schwabenländle
14.929 Beiträge
 
Turbo Delphi für Win32
 
#2

Re: Rekursion - Berechnung von Fakultäten

  Alt 17. Sep 2007, 23:21
Hallo,

richtig erkannt, result ist im Endeffekt vordefiniert und gibt ein Funktionsergebnis zurück. Anstelle von result kann man auch den Funktionsnamen verwenden, wenn ich das recht in Erinnerung habe.

Ohne Rückgabewert würde dir eine (rekursive) Funktion nichts bringen, da eine Funktion unter anderem dafür da ist, etwas zurückzugeben. Ich würde die Fakultät so berechnen (ungetestet):

Delphi-Quellcode:
function fakultaet(a: Integer): Integer;
begin
  if (a = 0) or (a = 1) then // 0! = 1! = 1
    result := 1
  else
    result := fakultaet(a - 1) * a;
end;
Das, worauf es ankommt bzw. das, was ein wenig Überlegung erfordert, ist der rekursive Aufruf, den du genau richtig erkannt hast:

zwsp := a * fakultaet(a-1) Das "Drumherum" mit dem Rückgabewert wirst du vermutlich gleich verstehen, sobald du den obigen Code verinnerlichst.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: Rekursion - Berechnung von Fakultäten

  Alt 18. Sep 2007, 06:36
Das result entspricht dem return in anderen Sprachen. Unter klassischem Pascal verwendete man, wie matze schon angedeutet hat den Namen der Funktion
result := fakultaet(a - 1) * a; ist also gleichbedeutend wie
fakultaet := fakultaet(a - 1) * a;
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Corpsman
Corpsman

Registriert seit: 8. Nov 2005
Ort: nähe Stuttgart
981 Beiträge
 
Delphi XE2 Professional
 
#4

Re: Rekursion - Berechnung von Fakultäten

  Alt 18. Sep 2007, 07:21
@MAtze

dir ist klar das der Aufruf mit Negativen Zahlen einen Stack overflow erzeugt ?
Uwe
My Sitewww.Corpsman.de

My marble madness clone Balanced ( ca. 70,0 mb ) aktuell ver 2.01
  Mit Zitat antworten Zitat
Benutzerbild von Matze
Matze
(Co-Admin)

Registriert seit: 7. Jul 2003
Ort: Schwabenländle
14.929 Beiträge
 
Turbo Delphi für Win32
 
#5

Re: Rekursion - Berechnung von Fakultäten

  Alt 18. Sep 2007, 07:38
Zitat von Corpsman:
dir ist klar das der Aufruf mit Negativen Zahlen einen Stack overflow erzeugt ?
Jupp, das ist mir klar. Natürlich hätte ich beispielsweise die negativen Zahlen negieren oder "-1" zurückgeben können. Ich wollte Ari lediglich zeigen, wie eine Rekursion funktioniert, den Rest darf er selbst machen.
  Mit Zitat antworten Zitat
Ari

Registriert seit: 7. Jan 2007
Ort: Wilhelmshaven
37 Beiträge
 
#6

Re: Rekursion - Berechnung von Fakultäten

  Alt 20. Sep 2007, 23:12
Hi nochmal,

sorry für die späte Antwort - funzt jetzt^^. Dankeschön
Ariane
  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 11:36 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