Discussion:
Halp ranking chess football
(zu alt für eine Antwort)
LuigiPaolo
2014-11-30 20:35:18 UTC
Permalink
Sorry for my bad english

the code mentioned below is part of an algorithm

to generate the list of a chess tournament (a bit more complex than
football).

Everything is based on the SET of Delphi7 and ranking

works perfectly only if the players do not exceed the number of 255.

The problem is that the SET can not contain more than 255 items

while a chess tournament can be up to 400-500 participants

Therefore I'm forced to work with arrays.

Some time ago I was suggested to use the functions

Contains and Procedure SetBit and below, respectively, instead of the

clause INCLUDE and IN of SET, the friend who sent me has

and I have not tested despite many efforts have failed

to solve the problem.

This would replace the IN clause and INCLUDE functions

suitable arrays.

I would also like to know how do you empty an array, with the SET

enough Set1 [] or Set2 []

Thanks for those who can help me by giving me even just a few ideas

Voltolini Luigi

Italy

?

///////// Suggested Functions

type

TMySet = array [0..63] of Byte; // 86 bytes = 512 bits

Contains function (const S: TMyset; bit: integer): boolean;

begin

Result: = (S [bit div 8] and (1 shr (bit mod 8))) <> 0;

end;

procedure SetBit (var S: TMyset; bit: integer);

begin

S [bit div 8]: = S [bit div 8] or (1 shr (bit mod 8));

end;

//////


?

Working code with the SET that replace

with ARRAY ....

?

?

////// Set1, Set2: set of 1..255;

?

Player with [ColumnA] do

begin

if (ColumnB in Set1) then begin

Include (Set2, ColumnB)

end;


if not (ColumnB in Set1) then begin

Include (Set1, ColumnB);

end;

....

Player with [ColumnB] do

begin

if (ColumnA in Set1) then begin

Include (Set2, ColumnA)

end;


if not (ColumnA in Set1) then begin

Include (Set1, ColumnA);

end;
Peter Below (TeamB)
2014-12-01 18:57:08 UTC
Permalink
Post by LuigiPaolo
Sorry for my bad english
the code mentioned below is part of an algorithm
to generate the list of a chess tournament (a bit more complex than
football).
Everything is based on the SET of Delphi7 and ranking
works perfectly only if the players do not exceed the number of 255.
The problem is that the SET can not contain more than 255 items
while a chess tournament can be up to 400-500 participants
Therefore I'm forced to work with arrays.
Don't, use the TBits class instead. As long as you only need
equivalents for In (membership test) and Include and Exclude Tbits can
be used pretty much as a set is used, and it has a way higher size
limit (High(integer)*8 if memory serves). What it does not support are
set operations (merging, intersecting, subtracting sets).

TBits acts like an array of boolean, so

var
LBits : TBits;

LBits := TBits.Create;
LBits.Size := NumberOfParticipants;
LBits[aParticipantIndex] := true; // equivalent of Include(aSet,
aParticipantIndex);
LBits[aParticipantIndex] := false; // equivalent of Exclude(aSet,
aParticipantIndex);
if LBits[aParticipantIndex] then // equivalent of if
aParticipantIndex In aSet then

If you do need set operations, see
http://codenewsfast.com/cnf/article/0/permalink.art-ng1616q53761
--
Peter Below (TeamB)
LuigiPaolo
2014-12-03 00:57:25 UTC
Permalink
TBits acts like an array of boolean, so

var

LBits : TBits;

LBits := TBits.Create;

LBits.Size := NumberOfParticipants;

LBits[aParticipantIndex] := true; // equivalent of
Include(aSet,aParticipantIndex);

LBits[aParticipantIndex] := false; // equivalent of
Exclude(aSet,aParticipantIndex);

if LBits[aParticipantIndex] then // equivalent of if aParticipantIndex In
aSet then

?

?

Sorry for my bad english

Thanks for your response.

how can I adapt your suggestion to my code under which

and if you can how can I replace the sets with arrays?

I no I did

Thanks again.

?

?

?

?

?

////// Set1, Set2: set of 1..255;

?

Player with [ColumnA] do

begin

if (ColumnB in Set1) then begin

Include (Set2, ColumnB)

end;


if not (ColumnB in Set1) then begin

Include (Set1, ColumnB);

end;

....

Player with [ColumnB] do

begin

if (ColumnA in Set1) then begin

Include (Set2, ColumnA)

end;


if not (ColumnA in Set1) then begin

Include (Set1, ColumnA);

end;

Loading...