AGB  ·  Datenschutz  ·  Impressum  







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

Stringparser-Problem

Ein Thema von guitar1 · begonnen am 10. Mär 2008 · letzter Beitrag vom 10. Mär 2008
Antwort Antwort
guitar1

Registriert seit: 9. Sep 2006
65 Beiträge
 
Turbo Delphi für Win32
 
#1

Stringparser-Problem

  Alt 10. Mär 2008, 14:11
hi,

ich habe mir einen kleine Stringpraser nachgebaut für +, -, * und / an sich nichts schweres, doch auch nach dem Studium dieses Artikels Artikel für einen komplexeren Praser stellt sich mir die Frage wie man das Problem bei mehrfacher Subtraktion lösen kann z.B. 100-2-2-2-2-2 = 90 nach dem Praser kommt als Ergebnis allerdings 98 heraus, was auch nach dem Methoden des Prasers logisch ist, denn er berechnet ja immer eine "Seite" des Terms, wobei er ja eigentlich 100-10 rechnen müsste.
Hat jemand von euch sich schon mal über dieses Problem gedanken gemacht oder vllt einen Lösungsvorschlag?

Hier ist noch mal der Code meines Prasers:
Delphi-Quellcode:
function Termberechnen(const Term: String):Extended;
var
  tmp1, tmp2: string;
begin
  if Pos('+', Term) > 0 then
  begin
    tmp1:= Trim(Copy(Term,1,Pos('+', Term)-1));
    tmp2:= Trim(Copy(Term,Pos('+', Term)+1, MaxInt));
    result:= Termberechnen(tmp1)+Termberechnen(tmp2);
  end
  else
  begin
    if Pos('-', Term) > 0 then
    begin
      tmp1:= Trim(Copy(Term,1,Pos('-', Term)-1));
      tmp2:= Trim(Copy(Term,Pos('-', Term)+1, MaxInt));
      result:= Termberechnen(tmp1)-Termberechnen(tmp2);
    end
    else
    begin
      if Pos('*', Term) > 0 then
      begin
        tmp1:= Trim(Copy(Term,1,Pos('*', Term)-1));
        tmp2:= Trim(Copy(Term,Pos('*', Term)+1, MaxInt));
        result:= Termberechnen(tmp1)*Termberechnen(tmp2);
      end
      else
      begin
        if Pos('/', Term) > 0 then
        begin
          tmp1:= Trim(Copy(Term,1,Pos('/', Term)-1));
          tmp2:= Trim(Copy(Term,Pos('/', Term)+1, MaxInt));
          result:= Termberechnen(tmp1)/Termberechnen(tmp2);
        end
        else
        begin
          if Term <> 'then
          begin
            result:= StrToFloat(Term);
          end
          else
          begin
            result:= 0;
          end;
        end;
      end;
    end;
  end;
end;
grüße
guitar1
http://www.myspace.com/metalinc1
http://andi1007.funpic.de
Thomann Cyberstore mein Tipp für alle die etwas für den Musikgebrauch brauchen =)
  Mit Zitat antworten Zitat
Benutzerbild von Fussball-Robby
Fussball-Robby

Registriert seit: 22. Okt 2007
Ort: Nähe Köln
1.063 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: Stringparser-Problem

  Alt 10. Mär 2008, 14:19
Also ich würds mit der while- oder repeat/until-Schleife machen und den Term so lange durchgehen, bis dass keines der Zeichen mehr vorhanden ist.

Mfg
Robert L.
  Mit Zitat antworten Zitat
Medium

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

Re: Stringparser-Problem

  Alt 10. Mär 2008, 14:24
Dadurch, dass du in der Rekursion jeweils zu erst den vordersten Operator wählst, löst du die Formel letztlich von hinten nach vorne. Du solltest also nicht das erste, sondern das jeweils letzte Vorkommen der Operatoren als Trennstelle verwenden um eine Links->Rechts Ordnung zu erhalten.
"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
guitar1

Registriert seit: 9. Sep 2006
65 Beiträge
 
Turbo Delphi für Win32
 
#4

Re: Stringparser-Problem

  Alt 10. Mär 2008, 16:04
@Medium: Vielen Dank für den Hinweis mit von links nach rechts, das wars, ich hab mir jetzt ein Pos geschrieben welches hinten anfängt zu suchen und dann klappts auch

hier für alle die das vllt mal gebrauchen können
Delphi-Quellcode:
function PosB(const AChar: Char; const str: String): Integer;
var
  i: Integer;
begin
  result:= 0;
  for i := Length(Str)-1 downto 0 do
  begin
    if str[i] = AChar then
    begin
      result:= i;
      break;
    end;
  end;
end;
http://www.myspace.com/metalinc1
http://andi1007.funpic.de
Thomann Cyberstore mein Tipp für alle die etwas für den Musikgebrauch brauchen =)
  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 08:38 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