www.vorhilfe.de
Vorhilfe

Kostenlose Kommunikationsplattform für gegenseitige Hilfestellungen.
Hallo Gast!einloggen | registrieren ]
Startseite · Forum · Wissen · Kurse · Mitglieder · Team · Impressum
Navigation
 Startseite...
 Neuerdings beta neu
 Forum...
 vorwissen...
 vorkurse...
 Werkzeuge...
 Nachhilfevermittlung beta...
 Online-Spiele beta
 Suchen
 Verein...
 Impressum
Das Projekt
Server und Internetanbindung werden durch Spenden finanziert.
Organisiert wird das Projekt von unserem Koordinatorenteam.
Hunderte Mitglieder helfen ehrenamtlich in unseren moderierten Foren.
Anbieter der Seite ist der gemeinnützige Verein "Vorhilfe.de e.V.".
Partnerseiten
Weitere Fächer:

Open Source FunktionenplotterFunkyPlot: Kostenloser und quelloffener Funktionenplotter für Linux und andere Betriebssysteme
Forum "Softwaretechnik und Programmierung" - Punkt vor Strichrechnung
Punkt vor Strichrechnung < Softwaretechnik+Pro < Praktische Inform. < Hochschule < Informatik < Vorhilfe
Ansicht: [ geschachtelt ] | ^ Forum "Softwaretechnik und Programmierung"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien

Punkt vor Strichrechnung: Borland C-Builder
Status: (Frage) beantwortet Status 
Datum: 22:20 Di 28.03.2006
Autor: Tobi15

Hallo,

für ein Projekt soll ich mit Hilfe des C-Builders von Boreland einen Taschenrechner programmieren, der bei allen Rechenoperationen, die Punkt vor Strich-Regel beachtet.

Bisher habe ich den Taschenrechner jediglich so programmiert, dass man jeweils nur Zwei zahlen miteinander verrechnen kann. Die erste Zahl wird hierfür immer in einer Hilfsvariablen zwischengespeichert.

Wie kann ich nun realisieren dass:

1. mehrere Zahlen z.B. (5+4+6+3=?) zu verrechnen sind.
2. bei den Rechenoperationen die Punkt vor Strich-Regel verwendet wird
    (z.B. 5+3*6=90!)

Vielen Dank im Vorraus

Tobi

        
Bezug
Punkt vor Strichrechnung: Eingabe 2x durchlaufen
Status: (Antwort) fertig Status 
Datum: 23:23 Di 28.03.2006
Autor: Karl_Pech

Hallo Tobi,


> für ein Projekt soll ich mit Hilfe des C-Builders von
> Boreland einen Taschenrechner programmieren, der bei allen
> Rechenoperationen, die Punkt vor Strich-Regel beachtet.


Klammerrechnung muß er also nicht können, das sollte es einfacher machen...


> Bisher habe ich den Taschenrechner lediglich so
> programmiert, dass man jeweils nur Zwei zahlen miteinander
> verrechnen kann. Die erste Zahl wird hierfür immer in einer
> Hilfsvariablen zwischengespeichert.
>  
> Wie kann ich nun realisieren dass:
>  
> 1. mehrere Zahlen z.B. (5+4+6+3=?) zu verrechnen sind.
>  2. bei den Rechenoperationen die Punkt vor Strich-Regel
> verwendet wird
>      (z.B. 5+3*6=90!)


Da hier keine Klammerrechnung vorkommen soll, sollte es reichen die Eingabe sequentiell zu durchlaufen:


1. Durchlauf: Löse alle '*';'/'-Terme, und ersetze sie durch die jeweiligen Ergebnisse.

2. Durchlauf: Löse nacheinander alle '+';'-'-Terme.


Zum 1ten Durchlauf:


~ Finde '*' oder '/':
   Wenn nicht Ende erreicht:
    Hole Zahl links vom Operator;
    Hole Zahl rechts vom Operator;
    Berechne; ersetze Term durch Ergebnis
    GOTO ~;

Zum 2ten Durchlauf:


~ Finde '-' oder '+':
   Wenn nicht Ende erreicht:
    Hole Zahl links vom Operator;
    Hole Zahl rechts vom Operator;
    Berechne; ersetze Term durch Ergebnis
    GOTO ~;


Da die beiden Durchläufe sich nur in den Operatoren unterscheiden, wäre es sinnvoll das in eine entsprechende Prozedur zu packen.

Na ja, und was die Richtigkeit dieser Vorgehensweise angeht. Ich sehe da eigentlich keine Probleme, da man bei dir ja ohne Klammerrechnung arbeitet.

Bei Klammerrechnung wird es schon wesentlich komplizierter, dort sind dann auch beliebig verschachteltbare Ausdrücke wie (1-((2*3+4)*6))/10 möglich. Da braucht man schon eine mächtigere Herangehensweise wie z.B. Operatoren-Bäume.



Viele Grüße
Karl





Bezug
        
Bezug
Punkt vor Strichrechnung: Antwort
Status: (Antwort) fertig Status 
Datum: 08:21 Mi 29.03.2006
Autor: kretschmer

Hallo Tobi15,

eine andere Möglichkeit gegenüber Karl-Pechs, wenn Du später Klammerrechnung hinzufügen willst, ist zuerst deine Eingabe in Tokens bestehend aus Operatoren und Zahlen aufzuteilen und diese dann mittels eines Parsers zu parsen, der dann direkt die Operationen durchführt. Klingt vielleicht kompliziert, ist es aber nicht. Das einfachste dürfte sein, das ganze mittels eines Parser-Generators, wie yacc, zu realisieren. Dann ist wirklich nicht viel Arbeit und Du hast Klammern gleich mit dabei.

--
Gruß
Matthias Kretschmer

Bezug
Ansicht: [ geschachtelt ] | ^ Forum "Softwaretechnik und Programmierung"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien


^ Seitenanfang ^
www.mathebank.de
[ Startseite | Forum | Wissen | Kurse | Mitglieder | Team | Impressum ]