AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Potenzberechnung mit Hilfe einer Rekursion
Thema durchsuchen
Ansicht
Themen-Optionen

Potenzberechnung mit Hilfe einer Rekursion

Offene Frage von "Xbe"
Ein Thema von Xbe · begonnen am 6. Okt 2009 · letzter Beitrag vom 7. Okt 2009
Antwort Antwort
Seite 2 von 3     12 3      
Xbe

Registriert seit: 6. Okt 2009
Ort: Beelitz
7 Beiträge
 
#11

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 6. Okt 2009, 18:03
@ Wolfgang

Soweit hab ich das jetzt auch verstanden, aber ich steuper immer noch über die Bedingung Rekursion(Wiederholung durch Selbstaufruf eines Algorithmus).

Wahrscheinlich iset zu einfach um das ichs umsetzen kann...
  Mit Zitat antworten Zitat
Benutzerbild von Mithrandir
Mithrandir
(CodeLib-Manager)

Registriert seit: 27. Nov 2008
Ort: Delmenhorst
2.379 Beiträge
 
#12

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 6. Okt 2009, 18:04
Zitat von Xbe:
Soweit hab ich das jetzt auch verstanden, aber ich steuper immer noch über die Bedingung Rekursion(Wiederholung durch Selbstaufruf eines Algorithmus).
Tut mir Leid,

aber ich versteh nicht, was du uns sagen willst...
米斯蘭迪爾
"In einer Zeit universellen Betruges wird das Aussprechen der Wahrheit zu einem revolutionären Akt." -- 1984, George Orwell
  Mit Zitat antworten Zitat
Xbe

Registriert seit: 6. Okt 2009
Ort: Beelitz
7 Beiträge
 
#13

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 6. Okt 2009, 18:16
@ Daniel G

hier mal nen Bsp für eine funktionierende Rekursion:

.
.
.
Delphi-Quellcode:
procedureTForm1.umkehren(Sender:TObject);
   var i,j:integer;
   prodedure umkehr(zeichen:char);
      begin
         i:=i+1;
         zeichen:=wort[i];
         if i<length(wort) then umkehr(wort[i]);
         stringgrid1.cells[j,0]:=zeichen;
         j=j+1;
      end;
   begin
      wort:=edit1.text;
      i:=0;
      j:=1;
      umkehr(wort[i]);
   end;
.
.
.

[edit=MrSpock]Code Tags eingefügt. Mfg, MrSpock[/edit]
  Mit Zitat antworten Zitat
Benutzerbild von Wolfgang Mix
Wolfgang Mix

Registriert seit: 13. Mai 2009
Ort: Lübeck
1.222 Beiträge
 
Delphi 2005 Personal
 
#14

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 6. Okt 2009, 18:32
@Xbe
Delphi-Quellcode:
function Potenz(Basis, Exponent: Integer): Int64;
begin
  if Exponent = 0 then
    Exit
  else
    Result := Basis * Potenz(Basis, Exponent - 1);
end;
Was ist denn hier grundlegend anders?
Du kennst schon den Unterschied zwischen Procedure und Function?

Gruß

Wolfgang
Wolfgang Mix
if you can't explain it simply you don't understand it well enough - A. Einstein
Mein Baby:http://www.epubli.de/shop/buch/Grund...41818516/52824
  Mit Zitat antworten Zitat
Xbe

Registriert seit: 6. Okt 2009
Ort: Beelitz
7 Beiträge
 
#15

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 6. Okt 2009, 18:59
@wolfgang
nee deshalb hab ich ja vorhin gefragt, weil wenn das der Kopf wäre ok aber weiterhin muss man ja zb die Variablen wie Exponent auch vorher bestimmen
  Mit Zitat antworten Zitat
Benutzerbild von Wolfgang Mix
Wolfgang Mix

Registriert seit: 13. Mai 2009
Ort: Lübeck
1.222 Beiträge
 
Delphi 2005 Personal
 
#16

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 6. Okt 2009, 19:14
@Xbe

Ich habe den Code aus dem angegebenen Link einmal ausprobiert, hier der Quälkot:

Delphi-Quellcode:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;

type
  TForm1 = class(TForm)
    Button1: TButton;
    Edit1: TEdit;
    procedure Button1Click(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

function Potenz(Basis, Exponent: Integer): Int64;
begin
  if Exponent = 0 then result:=1
  else
    Result := Basis * Potenz(Basis, Exponent - 1);
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  Edit1.Text:=IntToStr(Potenz(2,3));
end;

end.
Funzt hier soweit

Gruß

Wolgang
Wolfgang Mix
if you can't explain it simply you don't understand it well enough - A. Einstein
Mein Baby:http://www.epubli.de/shop/buch/Grund...41818516/52824
  Mit Zitat antworten Zitat
gammatester

Registriert seit: 6. Dez 2005
999 Beiträge
 
#17

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 6. Okt 2009, 23:43
Zitat von Wolfgang Mix:
Funzt hier soweit

Gruß

Wolgang
Hier nicht, da Potenz(2,-1) einen Stackoverflow gibt. Besser
Delphi-Quellcode:
function Potenz(Basis, Exponent: Integer): Int64;
begin
  if Exponent<0 then Result := 0
  else if Exponent = 0 then Result := 1
  else Result := Basis * Potenz(Basis, Exponent-1);
end;
oder Basis und Exponent als cardinal deklarieren.

Gruß Gammatester
  Mit Zitat antworten Zitat
Benutzerbild von Aphton
Aphton

Registriert seit: 31. Mai 2009
1.198 Beiträge
 
Turbo Delphi für Win32
 
#18

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 7. Okt 2009, 01:03
@Gammatester - Warum?

x^-y = 1/(x^y)



Delphi-Quellcode:
function Power( Base, Exponent: Integer ): Double;
begin
  if Exponent < 0 then
    Result := 1 / Power( Base, Abs( Exponent ) )
  else
    case Exponent of
      0: Result := 1;
      1: Result := Base;
    else
      Result := Base * Power( Base, Exponent - 1 );
    end;
end;
das Erkennen beginnt, wenn der Erkennende vom zu Erkennenden Abstand nimmt
MfG
  Mit Zitat antworten Zitat
Benutzerbild von Wolfgang Mix
Wolfgang Mix

Registriert seit: 13. Mai 2009
Ort: Lübeck
1.222 Beiträge
 
Delphi 2005 Personal
 
#19

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 7. Okt 2009, 09:13
Perfekt, jetzt muss man nur noch 0 hoch 0 abfangen.

Gruß

Wolfgang
Wolfgang Mix
if you can't explain it simply you don't understand it well enough - A. Einstein
Mein Baby:http://www.epubli.de/shop/buch/Grund...41818516/52824
  Mit Zitat antworten Zitat
gammatester

Registriert seit: 6. Dez 2005
999 Beiträge
 
#20

Re: Potenzberechnung mit Hilfe einer Rekursion

  Alt 7. Okt 2009, 09:19
Zitat von Aphton:
@Gammatester - Warum?

x^-y = 1/(x^y)

;)
Richtig. Und was ist 1/x^y für y>0,x>0? Für Integerwerte y>0, x>1 immer 0. Ich wollte in meinem Vorschlag nicht noch mehr Fallunterscheidungen einbringen. Es sollte aber spezifiziert werden, ob Integer oder Float gerechnet werden soll, und aus welchem Bereich die Argument kommen sollen.

Dein Vorschlag ändert unter der Hand die bisher diskutierte Funktionsdeklaration.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 3     12 3      


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 12:31 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