很明确的说是学校作业 只是本人一向并无向软件开发方面发展的意向 但请各位哒人相助 特此奉上一百分 以表微意

解决方案 »

  1.   

    {  根据TP3的TCALC例子制作的算式计算器。不是我写的.}PROCEDURE Eval(Formula : String;    { 要计算的表达式 }
                   VAR Value   : Real;      { 返回数值 }
                   VAR ErrPos  : Integer);  { 错误信息 }
      CONST
        Digit: Set of Char = ['0'..'9'];
      VAR
        Posn  : Integer;   { 算式当前位置 }
        CurrChar   : Char;      { 算式当前字符 }
    PROCEDURE ParseNext; 
    BEGIN
      REPEAT
        Posn:=Posn+1;
        IF Posn<=Length(Formula) THEN CurrChar:=Formula[Posn]
         ELSE CurrChar:=^M;
      UNTIL CurrChar<>' ';
    END  { ParseNext };
    FUNCTION add_subt: Real;
      VAR
        E   : Real;
        Opr : Char;  FUNCTION mult_DIV: Real;
        VAR
          S   : Real;
          Opr : Char;    FUNCTION Power: Real;
          VAR
            T : Real;      FUNCTION SignedOp: Real;        FUNCTION UnsignedOp: Real;
              TYPE
                StdFunc = (fabs,    fsqrt, fsqr, fsin, fcos,
                           farctan, fln,   flog, fexp, ffact);
                StdFuncList = ARRAY[StdFunc] of String[6];          CONST
                StdFuncName: StdFuncList =
                ('ABS','SQRT','SQR','SIN','COS',
                'ARCTAN','LN','LOG','EXP','FACT');
              VAR
                E, L, Start    : Integer;
                Funnet         : Boolean;
                F              : Real;
                Sf             : StdFunc;              FUNCTION Fact(I: Integer): Real;
                  BEGIN
                    IF I > 0 THEN BEGIN Fact:=I*Fact(I-1); END
                    ELSE Fact:=1;
                  END  { Fact };          BEGIN 
                IF CurrChar in Digit THEN
                BEGIN
                  Start:=Posn;
                  REPEAT ParseNext UNTIL not (CurrChar in Digit);
                  IF CurrChar='.' THEN REPEAT ParseNext UNTIL not (CurrChar in Digit);
                  IF CurrChar='E' THEN
                  BEGIN
                    ParseNext;
                    REPEAT ParseNext UNTIL not (CurrChar in Digit);
                  END;
                  Val(Copy(Formula,Start,Posn-Start),F,ErrPos);
                END ELSE
                IF CurrChar='(' THEN
                BEGIN
                  ParseNext;
                  F:=add_subt;
                  IF CurrChar=')' THEN ParseNext ELSE ErrPos:=Posn;
                END ELSE
                BEGIN
                  Funnet:=False;
                  FOR sf:=fabs TO ffact DO
                  IF not Funnet THEN
                  BEGIN
                    l:=Length(StdFuncName[sf]);
                    IF Copy(Formula,Posn,l)=StdFuncName[sf] THEN
                    BEGIN
                      Posn:=Posn+l-1; ParseNext;
                      f:=UnsignedOp;
                      CASE sf of
                        fabs:     f:=abs(f);
                        fsqrt:    f:=SqrT(f);
                        fsqr:     f:=Sqr(f);
                        fsin:     f:=Sin(f);
                        fcos:     f:=Cos(f);
                        farctan:  f:=ArcTan(f);
                        fln :     f:=LN(f);
                        flog:     f:=LN(f)/LN(10);
                        fexp:     f:=EXP(f);
                        ffact:    f:=fact(Trunc(f));
                      END;
                      Funnet:=True;
                    END;
                  END;
                  IF not Funnet THEN
                  BEGIN
                    ErrPos:=Posn;
                    f:=0;
                  END;
                END;
                UnsignedOp:=F;
              END { UnsignedOp};        BEGIN { SignedOp }
              IF CurrChar='-' THEN
              BEGIN
                ParseNext; SignedOp:=-UnsignedOp;
              END ELSE SignedOp:=UnsignedOp;
            END { SignedOp };      BEGIN { Power }
            T:=SignedOp;
            WHILE CurrChar='^' DO
            BEGIN
              ParseNext;
              IF t<>0 THEN t:=EXP(LN(abs(t))*SignedOp) ELSE t:=0;
            END;
            Power:=t;
          END { Power };
        BEGIN 
          s:=Power;
          WHILE CurrChar in ['*','/'] DO
          BEGIN
            Opr:=CurrChar; ParseNext;
            CASE Opr of
              '*': s:=s*Power;
              '/': s:=s/Power;
            END;
          END;
          mult_DIV:=s;
        END ;  BEGIN 
        E:=mult_DIV;
        WHILE CurrChar in ['+','-'] DO
        BEGIN
          Opr:=CurrChar; ParseNext;
          CASE Opr of
            '+': e:=e+mult_DIV;
            '-': e:=e-mult_DIV;
          END;
        END;
        add_subt:=E;
      END ;BEGIN 
      IF Formula[1]='.'
      THEN Formula:='0'+Formula;
      IF Formula[1]='+'
      THEN Delete(Formula,1,1);
      FOR Posn:=1 TO Length(Formula)
      DO Formula[Posn] := Upcase(Formula[Posn]);
      Posn:=0;
      ParseNext;
      Value:=add_subt;
      IF CurrChar=^M THEN ErrPos:=0 ELSE ErrPos:=Posn;
    END ;VAR
      Formula : String;
      Value   : Real;
      i, Err  : Integer;
    BEGIN
      REPEAT
        Writeln;
        Write('Enter formula (empty exits): '); Readln(Formula);
        IF Formula='' THEN Exit;
        Eval(Formula, Value, Err);
        Write(Formula);
        IF Err=0
        THEN Writeln(' = ',Value:0:5)
        ELSE BEGIN
          Writeln;
          FOR i:=1 TO Err-1 DO Write(' ');
          Writeln('^-- Error in formula');
        END;
      UNTIL False;
    END.