![]() |
Re: Menge von Integerzahlen schnell u. einfach merken?
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 |
Re: Menge von Integerzahlen schnell u. einfach merken?
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. |
Re: Menge von Integerzahlen schnell u. einfach merken?
Zitat:
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. |
Re: Menge von Integerzahlen schnell u. einfach merken?
Zitat:
Trotzdem vielen Dank an alle für die nützlichen Beiträge! |
Re: Menge von Integerzahlen schnell u. einfach merken?
Zitat:
es ist schnell, einfach und zudem lassen sich die Integer gut verwalten. ;) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:33 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-2025 by Thomas Breitkreuz