AGB  ·  Datenschutz  ·  Impressum  







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

Hilfe beim Algorithmus (Baumrekursion)

Ein Thema von Delphi-Noobie · begonnen am 8. Feb 2005 · letzter Beitrag vom 8. Feb 2005
 
Delphi-Noobie

Registriert seit: 28. Nov 2003
102 Beiträge
 
#1

Hilfe beim Algorithmus (Baumrekursion)

  Alt 8. Feb 2005, 17:23
hi,

Ich versuche eine Rekursive Funktion zu schreiben um ein Problem zu lösen, als Bsp: es seien 15 Frauen, eine Frau bekommt eine Nachricht und will sie den anderen erzählen, darf aber nur 2 andere Frauen benachrichtigen. Die beiden können wieder 2 Frauen benachrichtigen usw. (Baumdiagramm).
Beispielbaum:
Delphi-Quellcode:
 
 

                              F1
                           / \
                         F9 F2 // <- für 15 Personen
                       / \ / \
                   F10 F13 F3 F6
                    / \ / \ /\ / \
                  F11 F12 F14F15 F4F5 F7 F8
Alle Frauen werden in einer Procedure in einem Array gespeichert:

Delphi-Quellcode:
Type Frau = array of String;

procedure liste(N:Anzahl);
var i:integer;
begin
setlength(Frau,n);
for i:=0 to n-1 do frau[i]:='Person '+inttostr(i+1);
end;
Jetzt kommt die Funktion:

Delphi-Quellcode:
Type Endfrauen = record
    Frau1:String;
    Frau2:String;
end;

Function getfrauen(Ausgangsfrau:integer,Frauenarray:Frau):Endfrauen;
begin
// <- :(
end;
Die Funktion soll die 2 Frauen ausgeben, die die Ausgangsfrau benachrichtigt, in diesen fall würde z.B. Frau 9 - Frau 10 und Frau 13 benachrichtigen, also muss als ergebnis Person 10 und Person 13 raus kommen. Da es rekursiv gelöst werden soll müsste also Also der Rekursionsanfang erreicht sein, wenn n = 1 ist sonst soll er die Frauenliste durch 2 teilen und die Function nochmal aufrufen (irgendwie so). Aber mir fehlt leider die Vorstellung, wie ich das lösen könnte. Wüsste jemand ne Lösung?

Ps: es soll nicht so ein Baum werden, das Person1 - Person2 und 3 informiert, sondern so, wie oben gezeichnet nur ebend mit n* Frauen.
Wieviel Lösungen hat die Gleichung x^13=1? .... 13!
  Mit Zitat antworten Zitat
 


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 05:57 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz