AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Schnellste Überprüfung des Inhaltes eines Arrays
Thema durchsuchen
Ansicht
Themen-Optionen

Schnellste Überprüfung des Inhaltes eines Arrays

Ein Thema von HolgerCW · begonnen am 15. Nov 2007 · letzter Beitrag vom 15. Nov 2007
Antwort Antwort
Seite 1 von 2  1 2      
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#1

Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:17
Hallo zusammen,

habe ein Array mit Datums.

Wie kann ich ein Array am schnellsten danach abfragen, ob ein bestimmtes Datum in dem Array enthalten ist ?

Mit einer For-Schleife mache ich es zur Zeit. Das ist mir zu langsam.

Gruss

Holger
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.544 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:19
Ist das Array sortiert?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von RavenIV
RavenIV

Registriert seit: 12. Jan 2005
Ort: Waldshut-Tiengen
2.875 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:20
Soweit ich weiss, gibt es kein Array.Search oder Array.Find oder Array.Locate.
Wird Dir nichts anderes übrig bleiben, als das Array mit for oder while solange durchzugehen, bis das Element gefunden wurde.

Du kannst aber anstelle des Array eine TList nehmen.
Die bietet mehr Funktionen zum Verwalten der Items an.
Klaus E.
Linux - das längste Text-Adventure aller Zeiten...
Wer nie Linux mit dem vi konfiguriert hat, der hat am Leben vorbei geklickt.
  Mit Zitat antworten Zitat
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#4

Re: Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:23
IcCh könnte das Array sortiert aufbauen...

... und dann ?

Gruss

Holger
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.544 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:29
Du könntest es mit einer Näherung versuchen. Dazu ein Beispiel:
Nehmen wir an, Du hast ein Array mit den Zahlen von 1 bis 100 und suchst die 70. Nun kannst Du entweder das komplette Array durchlaufen (was Du ja nicht willst) oder Du gehst folgendermaßen vor. Zuerst "stichst" Du in die Mitte des Array (Length div 2) und siehst nach, welcher Wert dahintersteht. Ist der gesuchte Wert größer, suchst Du die Mitte zwischen dem aktuellen und dem größten Element, ist er kleiner, zwischen dem aktuellen und dem kleinsten Element und vergleichst wieder. Das wiederholst Du solange, bis der gesuchte Wert gefunden wurde oder der nächste ermittelte Index dem aktuellen entspricht. In letzterem Falle ist der Wert nicht enthalten.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Nuclear-Ping
(Gast)

n/a Beiträge
 
#6

Re: Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:33
Wieviele Einträge hat das Array denn?

Wenn es ziemlich viele sind, kann man es so sortieren, dass ein Monats- und Jahresbereich per Lookup angesprungen werden können.
Wenn du z.B. den 12.08.2001 suchst, könnte so gleich der Index-Bereich 2001-08 angesprungen werden.

Alternativ kann man auch überlegen, die Daten statt in einem Array in einer Datenbank abzulegen, die per SQL abzufragen ist. Da kann man z.B. "SELECT * FROM Dates WHERE (Month=8) AND (Year=2001)" machen, was auch ziemlich schnell sein sollte (ordentliche Indizes voraugesetzt) - oder "SELECT * FROM Dates WHERE (Day=12) AND (Month=8) AND (Year=2001)", um ein bestimmtes Datum zu finden. Wenn kein Ergebnis zurückgeliefert wird, existiert das Datum nicht.
  Mit Zitat antworten Zitat
taaktaak

Registriert seit: 25. Okt 2007
Ort: Radbruch
1.990 Beiträge
 
Delphi 7 Professional
 
#7

Re: Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:35
Moin Holger,
wie würdest du in einem Kartenspiel möglichst effizient nach einer bestimmten Karte suchen? Durch halbieren der Kartenmenge! Du fragst: Ist es eine rote oder schwarze Karte, Bild oder Zahl etc.
In einem sortierten Array machst du es vergleichbar: Du fängst in der Mitte an und prüfst ob dein Wert größer oder kleiner als das ArrayElement in der Mitte ist. Dann machst du die gleiche Prüfung in der Mitte der übrig gebliebenen Menge etc. So findest du in einem sortierten Array mit wenigen Schritten das gesuchte Element..
Gruß Ralph

// ahh, zu langsam
Ralph
  Mit Zitat antworten Zitat
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#8

Re: Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:35
Alles klar,

das habe ich schon mal Informatikunterricht gehört. Werde ich ausprobieren mit dem halbieren und wieder halbieren u.s.w.

Zu der TList:

Wie kann ich bei einer TList ein Datum hinzufügen. Der will einen "Pointer" haben ? So geht es nicht:

ListSchicht.Add(datetostr(Datum)); Ist das richtig um das Datum wieder zu finden:

Delphi-Quellcode:
if ListSchicht[ListSchicht.IndexOf(Datum)] <> 'then
begin

 testing := testing;

end;
  Mit Zitat antworten Zitat
taaktaak

Registriert seit: 25. Okt 2007
Ort: Radbruch
1.990 Beiträge
 
Delphi 7 Professional
 
#9

Re: Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:43
Moin Holger,
neee, du musst mit new() erst einmal Speicher für dein Datum anlegen und den Pointer auf diesen Speicherbereich an deine Liste übergeben... Gibt es einen besonderen Grund, dass du das nicht mit einer StringList machen willst? Ist vielleicht weniger elegant aber einfacher
Gruß Ralph
Ralph
  Mit Zitat antworten Zitat
Nuclear-Ping
(Gast)

n/a Beiträge
 
#10

Re: Schnellste Überprüfung des Inhaltes eines Arrays

  Alt 15. Nov 2007, 11:44
Versuchs mal mit einer TStringList statt TList. Das dürfte auch gut gehen.

Delphi-Quellcode:
var
  ListSchicht: TStringList;
begin
  ListSchicht := TStringList.Create;

  try
    ListSchicht.Add (FormatDateTime ('dd.mm.yyyy', Now {oder jedes andere TDateTime Datum}));

    if ListSchicht.IndexOf ('01.01.2008') = -1 then
      // Datum nicht vorhanden
    else
     // Datum vorhanden
  finally
    FreeAndNil (ListSchicht);
  end;
end;
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 20:08 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