AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Menge von Integerzahlen schnell u. einfach merken?
Thema durchsuchen
Ansicht
Themen-Optionen

Menge von Integerzahlen schnell u. einfach merken?

Ein Thema von PeterPanino · begonnen am 21. Mai 2008 · letzter Beitrag vom 21. Mai 2008
Antwort Antwort
Seite 2 von 2     12   
Horst_

Registriert seit: 22. Jul 2004
Ort: Münster Osnabrück
116 Beiträge
 
#11

Re: Menge von Integerzahlen schnell u. einfach merken?

  Alt 21. Mai 2008, 10:09
Hallo,

wenn der Wertebereich der Intgervariablen bekannt und klein ist (Bleibt dem Anwender überlassen ob 1000 oder 100 mio klein ist) legt man nur ein Feld für den Wertebereich an und zählt das jeweiige vorkommen. Dann sind die Daten sogar sortiert.

Gruß Horst
  Mit Zitat antworten Zitat
BloodySmartie
(Gast)

n/a Beiträge
 
#12

Re: Menge von Integerzahlen schnell u. einfach merken?

  Alt 21. Mai 2008, 10:20
Das erinnert mich an das Buch "Perlen der Programmierkunst".

Problematik: Sortiere eine Menge an 8-stelligen Telefonnummern, entferne doppelte Zahlen und das bitte in minimaler Zeit und mit minimalem Speicherverbrauch.

Lösung: ein Bit-Array, dessen Index die Tel-Nr. darstellt und dessen Wert einfach nur anzeigt, ob sie in der Menge vorhanden ist oder nicht. Ums Sortieren und um Dubletten muss man sich gar nicht kümmern.
  Mit Zitat antworten Zitat
Tyrael Y.

Registriert seit: 28. Jul 2003
Ort: Stuttgart
1.093 Beiträge
 
Delphi 2007 Professional
 
#13

Re: Menge von Integerzahlen schnell u. einfach merken?

  Alt 21. Mai 2008, 10:55
Zitat von SirThornberry:
ich persönlich würde ein Array nehmen. Allerdings ist genau so gut auch eine TList. Nichts mit ableiten etc. Die TList verwaltet Pointer welche 32 bit groß sind. Integer sind ebenfalls 32bit groß. Entsprechend kann man durch einen einfachen Cast auch Integer darin speichern. Denn letztendlich ist es eine Interpretationssache ob man das was im Speicher steht als Integer, Pointer, String etc. ansieht.
So ist es...wenn du zu faul bist das Casten in Integer selbst zu übernehmen, dann google mal nach TIntegerList....ist eine gaaaanz einfache und auch selbst schnell getippte Ableitung von TList.


Edit:
Hier für faule...es kann natürlich noch erweitert werden.

Delphi-Quellcode:
unit IntegerList;

interface

uses
  Classes;

type
  TIntegerListSortCompare = function (Item1, Item2: Pointer): Integer;
  TIntegerList = class(TList)
  private
    function Get(Index: Integer): Integer; reintroduce;
    procedure Put(Index: Integer; const Value: Integer); reintroduce;
  public
    function Add(Item: Integer): Integer; reintroduce;
    function Extract(Item: Integer): Integer; reintroduce;
    function IndexOf(Item: Integer): Integer; reintroduce;
    procedure Insert(Index: Integer; Item: Integer); reintroduce;
    function Last: Integer; reintroduce;
    function Remove(Item: Integer): Integer; reintroduce;
    procedure Sort(Compare: TIntegerListSortCompare); reintroduce;
    property Items[Index: Integer]: Integer read Get write Put; default;
  end;

implementation

{ TIntegerList }

function TIntegerList.Add(Item: Integer): Integer;
begin
  Result := inherited Add(Pointer(Item));
end;

function TIntegerList.Extract(Item: Integer): Integer;
begin
  Result := Integer(inherited Extract(Pointer(Item)));
end;

function TIntegerList.Get(Index: Integer): Integer;
begin
  Result := Integer(inherited Items[Index]);
end;

function TIntegerList.IndexOf(Item: Integer): Integer;
begin
  result := inherited IndexOf(Pointer(Item));
end;

procedure TIntegerList.Insert(Index, Item: Integer);
begin
  inherited Insert(Index, Pointer(Item));
end;

function TIntegerList.Last: Integer;
begin
  Result := Integer(inherited Last);
end;

procedure TIntegerList.Put(Index: Integer; const Value: Integer);
begin
  inherited Items[Index] := Pointer(Value);
end;

function TIntegerList.Remove(Item: Integer): Integer;
begin
  Result := inherited Remove(Pointer(Item));
end;

procedure TIntegerList.Sort(Compare: TIntegerListSortCompare);
begin
  inherited Sort(TListSortCompare(Compare));
end;

end.
Levent Yildirim
Erzeugung von Icons aus Bildern:IconLev
  Mit Zitat antworten Zitat
PeterPanino

Registriert seit: 4. Sep 2004
1.465 Beiträge
 
Delphi 10.4 Sydney
 
#14

Re: Menge von Integerzahlen schnell u. einfach merken?

  Alt 21. Mai 2008, 12:25
Zitat von Tyrael Y.:
So ist es...wenn du zu faul bist das Casten in Integer selbst zu übernehmen, dann google mal nach TIntegerList....ist eine gaaaanz einfache und auch selbst schnell getippte Ableitung von TList.[/delphi]
Kommt darauf an, wofür man die Liste braucht. Die Ausgangsanforderung war ja: Schnell und einfach mal ein paar Integers merken.

Trotzdem vielen Dank an alle für die nützlichen Beiträge!
  Mit Zitat antworten Zitat
Tyrael Y.

Registriert seit: 28. Jul 2003
Ort: Stuttgart
1.093 Beiträge
 
Delphi 2007 Professional
 
#15

Re: Menge von Integerzahlen schnell u. einfach merken?

  Alt 21. Mai 2008, 12:32
Zitat von PeterPanino:
Kommt darauf an, wofür man die Liste braucht. Die Ausgangsanforderung war ja: Schnell und einfach mal ein paar Integers merken.

Trotzdem vielen Dank an alle für die nützlichen Beiträge!
120% der Anforderungen erfüllt würde ich sagen

es ist schnell, einfach und zudem lassen sich die Integer gut verwalten.
Levent Yildirim
Erzeugung von Icons aus Bildern:IconLev
  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 22:12 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