AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Projekte TBigUInt - Noch ein Datentyp für große Zahlen
Thema durchsuchen
Ansicht
Themen-Optionen

TBigUInt - Noch ein Datentyp für große Zahlen

Ein Thema von Neutral General · begonnen am 25. Mai 2009 · letzter Beitrag vom 27. Mai 2009
Antwort Antwort
Seite 2 von 2     12   
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.487 Beiträge
 
Delphi 12 Athens
 
#1

Re: TBigUInt - Noch ein Datentyp für große Zahlen

  Alt 27. Mai 2009, 10:34
Vorschlag für StrToInt:
Delphi-Quellcode:
uses
  SysConst;

function StrToInt(const S: String): TBigUInt;
var
  n: String;
  i: Integer;
  c: char;
begin
  {Leerzeichen am Anfang und Ende entfernen}
  n := Trim(s);

  if Length(n) = 0 then
    raise EConvertError.CreateResFmt(@SInvalidInteger, [S]);

  Result := 0;
  for i := 1 to Length(n) do
  begin
    c := n[i];
    if (c < '0') or (c > '9') then
      raise EConvertError.CreateResFmt(@SInvalidInteger, [S]);

    Result := Result * 10 + (Ord(c) - Ord('0'));
  end;
end;
Auf jeden Fall sollten auch negative Zahlen unterstützt werden, sonst ist der Typ zu sehr eingeschränkt.

Edit: n[1] durch n[i] ersetzt
gut das einer aufpasst
  Mit Zitat antworten Zitat
gammatester

Registriert seit: 6. Dez 2005
999 Beiträge
 
#2

Re: TBigUInt - Noch ein Datentyp für große Zahlen

  Alt 27. Mai 2009, 12:11
Zitat von Blup:
Vorschlag für StrToInt:
Delphi-Quellcode:
{...}
c := n[1];
Auf jeden Fall sollten auch negative Zahlen unterstützt werden, sonst ist der Typ zu sehr eingeschränkt.
Du meinst doch bestimmt c := n[i];
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.326 Beiträge
 
Delphi 12 Athens
 
#3

Re: TBigUInt - Noch ein Datentyp für große Zahlen

  Alt 27. Mai 2009, 12:34
würde es ein bissl beschleunigen, wenn nicht für jede Stelle mit der großen Zahl gerechnet würde
(praktisch die Umkehrung des IntToStr)
Delphi-Quellcode:
Result := 0;
i2 := 0;
i3 := 1;
for i := 1 to Length(n) do
begin
  if not (n[i] in ['0'..'9']) then
    raise EConvertError.CreateResFmt(@SInvalidInteger, [S]);
  i2 := i2 * 10 + (Ord(n[i]) - Ord('0'));
  i3 := i3 * 10;
  
  if (i3 = 1000000000) or (i = Length(n)) then
  begin
    Result := Result * i3 + i2;
    i2 := 0;
    i3 := 1;
  end;
end;
[edit] i2 durch i3 ersetzt (siehe gammatester)
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
gammatester

Registriert seit: 6. Dez 2005
999 Beiträge
 
#4

Re: TBigUInt - Noch ein Datentyp für große Zahlen

  Alt 27. Mai 2009, 13:13
Zitat von himitsu:
if (i2 = 1000000000) or (i = Length(n)) then {...}
Besser ist wohl
if (i3 = 1000000000) or (i = Length(n)) then {...}
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 06:15 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz