AGB  ·  Datenschutz  ·  Impressum  







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

aus infix aufgabe Binärbaum erstellen

Ein Thema von praesident · begonnen am 12. Apr 2008 · letzter Beitrag vom 12. Apr 2008
Antwort Antwort
praesident

Registriert seit: 29. Feb 2008
25 Beiträge
 
#1

aus infix aufgabe Binärbaum erstellen

  Alt 12. Apr 2008, 12:47
Hallo miteinander,


wir müssen in der Schule folgendes Programm schreiben:

Der user soll einen vollständig geklammerten Infix-Term eingeben. z.b. ((3+5)*9)+(3*7)

Aus diesem soll dann mittels canvas ein Binärbaum gezeichnet werden.

Das ganze soll rekusiv erfolgen, allerdings habe ich im Moment noch nicht mal einen Ansatz.

Hättet ihr viellt. ein paar Lösungsvorschläge oder ein Beispielprogramm (z.B. Welche Parameter sollte ich verwenden?) ?


Ich muss aber noch dazu sagen, dass wir noch keine Klassen behandelt haben.


Wäre euch für eure Hilfe sehr Dankbar

mfg
  Mit Zitat antworten Zitat
Macci

Registriert seit: 31. Mai 2007
129 Beiträge
 
#2

Re: aus infix aufgabe Binärbaum erstellen

  Alt 12. Apr 2008, 14:08
Hi,

naja erstmal solltest du den ganzen Ausdruck pharsen, dazu solltest du dir die Funktionen Copy, Pos und Trim anschauen und eine Objektstruktur abspeichern. Auch wenn ihr Klassen noch nicht hattet: Mach es trotzdem so. Klassen bieten sich hier geradezu an.
z.B. Könntest du eine abstrakte Klasse "Expression" schreiben, die dann Nachfahren des Typs "Addition", "Subtraktion", usw. und "Zahl" hat.

Die Klasse Expression könnte dann eine Methode Draw(Left,Right,Top:integer); haben, die den Ausdruck im Bereich zwischen Left und Right, ab y-Kooridinate Top zeichnet. Das Rechenzeichen, welches du mit "if Self is Addition then rechenzeichen:='+';" usw. bestimmen kannst, musst du dann lediglich in die Mitte hinschreiben, zwei schräge Striche zeichen, und dann ganz einfach "Draw(Left, (Left+Right) div 2, Top + HOEHE_EINER_EBENE);" für den linken Ast und "Draw((Left+Right) div 2+1, Right, Top +HOEHE_EINER_EBENE);" für den rechten Ast rekursiv aufrufen.


Jetzt musst du nach dem Pharsen nur noch einmal die Methode "Draw(0, Canvas.Width-1, 0);" für den obersten Ausdruck aufrufen, und das wars dann schon

Viele Grüsse,
Macci
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.679 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: aus infix aufgabe Binärbaum erstellen

  Alt 12. Apr 2008, 17:14
Zitat von Macci:
pharsen
Macht weiteres Suchen einfacher
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  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 22: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