AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Berechnung von gleichzeitigen Zugriffen
Thema durchsuchen
Ansicht
Themen-Optionen

Berechnung von gleichzeitigen Zugriffen

Ein Thema von msickel · begonnen am 1. Apr 2010 · letzter Beitrag vom 6. Apr 2010
Antwort Antwort
Seite 2 von 2     12   
msickel

Registriert seit: 14. Mai 2005
108 Beiträge
 
Delphi 2005 Professional
 
#11

Re: Berechnung von gleichzeitigen Zugriffen

  Alt 1. Apr 2010, 12:54
Zitat von s.h.a.r.k:
Hier mal meine Idee als Algo, nur noch ein wenig optimiert:
Delphi-Quellcode:
type
  TTimePeriod = record
    StartTimestamp : TDateTime;
    EndTimestamp : TDateTime;
  end;

  TTimePeriodArray = array of TTimePeriod;


function GetMaxTimeOverlaps(const ATimePeriods : TTimePeriodArray): Integer;
var
  TimeArray : array [0..1439] of Integer;
  tp : TTimePeriod;
  i : Integer;
  n : Integer;
  IndexStart, IndexEnd : Integer;
  Maximum, Value: Integer;
begin
  // Verteilung der Zeiten auf das Array
  Maximum := 1;
  for i := 0 to Length(ATimePeriods) - 1 do
  begin
    tp := ATimePeriods[i];

    IndexStart := HourOf(tp.StartTimestamp) * 60 + MinuteOf(tp.StartTimestamp);
    IndexEnd := HourOf(tp.EndTimestamp) * 60 + MinuteOf(tp.EndTimestamp);

    for n := IndexStart to IndexEnd do
    begin
      Value := TimeArray[n];
      Inc(Value);
      if (Value > Maximum) then
        Maximum := Value;
      TimeArray[n] := Value;
    end;
  end;
  Result := Maximum - 1;
end;
Das werde ich über Ostern bestimmt mal austesten, danke schon mal

Martin
ich weiss, das ich nichts weiss!
  Mit Zitat antworten Zitat
msickel

Registriert seit: 14. Mai 2005
108 Beiträge
 
Delphi 2005 Professional
 
#12

Re: Berechnung von gleichzeitigen Zugriffen

  Alt 5. Apr 2010, 20:06
Hi hab mal den Code getestet anbei der Testcode

Delphi-Quellcode:
unit Unit2;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, DateUtils, StdCtrls;

type
  TForm2 = class(TForm)
    Button1: TButton;
    Label1: TLabel;
    procedure Button1Click(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

type
  TTimePeriod = record
    StartTimestamp : TDateTime;
    EndTimestamp : TDateTime;
  end;

  TTimePeriodArray = array of TTimePeriod;

var
  Form2: TForm2;



implementation

{$R *.dfm}

function GetMaxTimeOverlaps(const ATimePeriods : TTimePeriodArray): Integer;
var
  TimeArray : array [0..1439] of Integer;
  tp : TTimePeriod;
  i : Integer;
  n : Integer;
  IndexStart, IndexEnd : Integer;
  Maximum, Value: Integer;
begin
  // Verteilung der Zeiten auf das Array
  Maximum := 1;
  for i := 1 to Length(ATimePeriods) - 1 do
  begin
    tp := ATimePeriods[i];

    IndexStart := HourOf(tp.StartTimestamp) * 60 + MinuteOf(tp.StartTimestamp);
    IndexEnd := HourOf(tp.EndTimestamp) * 60 + MinuteOf(tp.EndTimestamp);

    for n := IndexStart to IndexEnd do
    begin
      Value := TimeArray[n];
      Inc(Value);
      if (Value > Maximum) then
        Maximum := Value;
      TimeArray[n] := Value;
    end;
  end;
  Result := Maximum - 1;
end;

procedure TForm2.Button1Click(Sender: TObject);
var
  TimeTabelle : TTimePeriodArray;
begin

  SetLength(TimeTabelle, 5);

  TimeTabelle[0].StartTimestamp := StrToDateTime('21.03.2010 14:13');
  TimeTabelle[0].EndTimestamp := StrToDateTime('21.03.2010 14:33');
  TimeTabelle[1].StartTimestamp := StrToDateTime('22.03.2010 14:13');
  TimeTabelle[1].EndTimestamp := StrToDateTime('22.03.2010 14:33');
  TimeTabelle[2].StartTimestamp := StrToDateTime('22.03.2010 14:13');
  TimeTabelle[2].EndTimestamp := StrToDateTime('22.03.2010 14:33');
  TimeTabelle[3].StartTimestamp := StrToDateTime('22.03.2010 14:13');
  TimeTabelle[3].EndTimestamp := StrToDateTime('22.03.2010 14:33');
  TimeTabelle[4].StartTimestamp := StrToDateTime('22.03.2010 14:13');
  TimeTabelle[4].EndTimestamp := StrToDateTime('22.03.2010 14:33');
  TimeTabelle[5].StartTimestamp := StrToDateTime('22.03.2010 14:13');
  TimeTabelle[5].EndTimestamp := StrToDateTime('22.03.2010 14:33');


  label1.Caption := IntToStr(GetMaxTimeOverlaps(TimeTabelle));
end;

end.
habe das mal übers Wochenende getestet, eigentlich sollte das Ergebnis 5 sein. Leider ist das aber nicht so, wo liegt der Fehler?

Martin
ich weiss, das ich nichts weiss!
  Mit Zitat antworten Zitat
Klaus01
Online

Registriert seit: 30. Nov 2005
Ort: München
5.755 Beiträge
 
Delphi 10.4 Sydney
 
#13

Re: Berechnung von gleichzeitigen Zugriffen

  Alt 5. Apr 2010, 20:09
.. was hast denn Du für ein Ergebnis bekommen? "1"?

Delphi-Quellcode:
for n := IndexStart to IndexEnd do
  begin
    Value := TimeArray[n];
    Inc(Value);
    if (Value > Maximum) then // wenn es hilft > mit >= ersetzen
      Maximum := Value;
    TimeArray[n] := Value;
  end;
Grüße
Klaus
Klaus
  Mit Zitat antworten Zitat
msickel

Registriert seit: 14. Mai 2005
108 Beiträge
 
Delphi 2005 Professional
 
#14

Re: Berechnung von gleichzeitigen Zugriffen

  Alt 5. Apr 2010, 20:16
Das Ergebnis ist 1988236220

Die Änderung bringt keine Änderung am Ergebnis
Gruss Martin

Zitat von Klaus01:
.. was hast denn Du für ein Ergebnis bekommen? "1"?

Delphi-Quellcode:
for n := IndexStart to IndexEnd do
  begin
    Value := TimeArray[n];
    Inc(Value);
    if (Value > Maximum) then // wenn es hilft > mit >= ersetzen
      Maximum := Value;
    TimeArray[n] := Value;
  end;
Grüße
Klaus
ich weiss, das ich nichts weiss!
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.429 Beiträge
 
Delphi 10.4 Sydney
 
#15

Re: Berechnung von gleichzeitigen Zugriffen

  Alt 6. Apr 2010, 09:02
Ich würde TimeArray erst einmal mit 0 initialisieren.
  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 13:30 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