Thema: Delphi Laaaaange Zahlen

Einzelnen Beitrag anzeigen

Benutzerbild von LDericher
LDericher

Registriert seit: 29. Jan 2007
Ort: Erkelenz
224 Beiträge
 
Delphi 7 Enterprise
 
#1

Laaaaange Zahlen

  Alt 14. Nov 2008, 16:12
Ich bin dabei, eine Klasse zu schreiben, die mit sehr großen Ganzzahlen umgehen können soll. Also richtig lange Zahlen mit durchaus mehr als 1000 Stellen... auch BIGINT oder dergleichen hilft also nicht.

So weit, so gut: Nun bin ich dabei, die Subtraktionsroutine zu coden, scheitere aber in dem Fall, dass die Zahl negativ wird...
Hat jemand 'ne Idee?

Hier der Overhead:
Delphi-Quellcode:
  TLangzahl=class
  private
    vContent:TContent;
    IsNeg:boolean;
    procedure setContent(New:string);
    function getContent:string;
  public
    property Content:string read getContent write setContent;
    constructor Create;
    procedure Add(LZ:TLangzahl);
    procedure Increase;
    procedure Subtract(LZ:TLangzahl);
    procedure Decrease;
    procedure Multiply(LZ:TLangzahl);
    procedure Divide(LZ:TLangzahl);
    procedure Power(LZ:TLangzahl);
    procedure genRoot;
    destructor Destroy;
  end;
Hier die Beta-Subtraktionsmethode:
Delphi-Quellcode:
procedure TLangzahl.Subtract(LZ:TLangzahl);
var
  I,
  MaxLength:integer;
begin
if not(LZ.IsNeg)then
  begin
  MaxLength:=Max(High(vContent), High(LZ.vContent));
  SetLength(LZ.vContent, MaxLength+1);
  SetLength(vContent, MaxLength+1);
  for I:=0 to MaxLength do
     begin
     vContent[I]:=vContent[I]-LZ.vContent[I];
     if(vContent[I]<0)then
       begin
       vContent[I+1]:=vContent[I+1]-1;
       vContent[I]:=vContent[I] +10;
       end;
     end;
  end else Add(LZ);
end;
Liefert zum Beispiel (zugegeben: sinnvollerweise) "9" für "3-4"...

Danke im Voraus,
Euer LDer

Edit: TContent ist übrigens als array of Byte deklariert
  Mit Zitat antworten Zitat