|
|
|
@ -24,41 +24,86 @@ namespace TheGameExtreme.model.deck
|
|
|
|
|
return deck[index];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//protected void InsertionDichotomique(List<Card> deck, int start, int end, Card card)
|
|
|
|
|
//{
|
|
|
|
|
// int mediane = (end - start) % 2 + start;
|
|
|
|
|
// if (mediane > deck.Count - 1)
|
|
|
|
|
// {
|
|
|
|
|
// deck.Add(card);
|
|
|
|
|
// return;
|
|
|
|
|
// }
|
|
|
|
|
// int comparateur = deck[mediane].Value.CompareTo(card.Value);
|
|
|
|
|
// if (mediane == end)
|
|
|
|
|
// {
|
|
|
|
|
// if (comparateur > 0)
|
|
|
|
|
// {
|
|
|
|
|
// deck.Insert(start, card);
|
|
|
|
|
// }
|
|
|
|
|
// else
|
|
|
|
|
// {
|
|
|
|
|
// deck.Insert(end, card);
|
|
|
|
|
// }
|
|
|
|
|
// return;
|
|
|
|
|
// }
|
|
|
|
|
// if (comparateur == 0)
|
|
|
|
|
// {
|
|
|
|
|
// return;
|
|
|
|
|
// }
|
|
|
|
|
// else if (comparateur > 0)
|
|
|
|
|
// {
|
|
|
|
|
// InsertionDichotomique(deck, start, mediane, card);
|
|
|
|
|
// return;
|
|
|
|
|
// }
|
|
|
|
|
// else
|
|
|
|
|
// {
|
|
|
|
|
// InsertionDichotomique(deck, mediane, end, card);
|
|
|
|
|
// return;
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
protected void InsertionDichotomique(List<Card> deck, int start, int end, Card card)
|
|
|
|
|
{
|
|
|
|
|
if (deck.Count == 0)
|
|
|
|
|
{
|
|
|
|
|
deck.Add(card);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int mediane = (end - start) / 2 + start;
|
|
|
|
|
int comparateur = deck[mediane].Value.CompareTo(card.Value);
|
|
|
|
|
|
|
|
|
|
if (comparateur == 0)
|
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (mediane == start)
|
|
|
|
|
{
|
|
|
|
|
if (comparateur < 0)
|
|
|
|
|
{
|
|
|
|
|
if (deck[end].Value.CompareTo(card.Value) < 0)
|
|
|
|
|
{
|
|
|
|
|
deck.Insert(end + 1, card);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
deck.Insert(end, card);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
deck.Insert(start, card);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (comparateur < 0)
|
|
|
|
|
{
|
|
|
|
|
InsertionDichotomique(deck, mediane, end, card);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
InsertionDichotomique(deck, start, mediane, card);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//int mediane = (end - start) / 2 + start;
|
|
|
|
|
//int comparateur = deck[mediane].Value.CompareTo(card.Value);
|
|
|
|
|
//if (mediane == end)
|
|
|
|
|
//{
|
|
|
|
|
// if (comparateur < 0)
|
|
|
|
|
// {
|
|
|
|
|
// deck.Insert(start, card);
|
|
|
|
|
// }
|
|
|
|
|
// else
|
|
|
|
|
// {
|
|
|
|
|
// deck.Insert(end, card);
|
|
|
|
|
// }
|
|
|
|
|
// return;
|
|
|
|
|
//}
|
|
|
|
|
//if (comparateur == 0)
|
|
|
|
|
//{
|
|
|
|
|
// return;
|
|
|
|
|
//}
|
|
|
|
|
//else if (comparateur < 0)
|
|
|
|
|
//{
|
|
|
|
|
// InsertionDichotomique(deck, start, mediane, card);
|
|
|
|
|
// return;
|
|
|
|
|
//}
|
|
|
|
|
//else
|
|
|
|
|
//{
|
|
|
|
|
// InsertionDichotomique(deck, mediane, end, card);
|
|
|
|
|
// return;
|
|
|
|
|
//}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|