|
|
@ -18,7 +18,6 @@ namespace TheGameExtreme.model.gameActions.classic
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (CurrentHand.Count == 0 || CurrentCardPlayed.Count >= 2)
|
|
|
|
if (CurrentHand.Count == 0 || CurrentCardPlayed.Count >= 2)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Vérifier la fin du jeu
|
|
|
|
|
|
|
|
return true;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
@ -31,7 +30,80 @@ namespace TheGameExtreme.model.gameActions.classic
|
|
|
|
|
|
|
|
|
|
|
|
override protected void tryToFindSoluce(List<Card> playableCard, List<Card> CurrentHand)
|
|
|
|
override protected void tryToFindSoluce(List<Card> playableCard, List<Card> CurrentHand)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CurrentHand.ForEach(card =>
|
|
|
|
int findDownCard = 0;
|
|
|
|
|
|
|
|
int findUpCard = 0;
|
|
|
|
|
|
|
|
List<Card> hand = new List<Card>();
|
|
|
|
|
|
|
|
List<Card> playableDownCard = new List<Card>();
|
|
|
|
|
|
|
|
List<Card> playableUpCard = new List<Card>();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CurrentHand.ForEach(card => hand.Add(card));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
hand.ForEach(card =>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
for (int i = 0; i < ListOrderedStacks.Size; i++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 10) == 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
playableDownCard.Add(card);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 10) == 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
playableUpCard.Add(card);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
playableDownCard.ForEach(card =>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
hand.Remove(card);
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
playableUpCard.ForEach(card =>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
hand.Remove(card);
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
while ((playableDownCard.Count > findDownCard || playableUpCard.Count > findUpCard) && hand.Count > 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
findDownCard = playableDownCard.Count;
|
|
|
|
|
|
|
|
findUpCard = playableUpCard.Count;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
hand.ForEach(card =>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
for (int i = 0; i < playableDownCard.Count; i++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 10) == 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
playableDownCard.Add(card);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i = 0; i < playableUpCard.Count; i++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 10) == 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
playableUpCard.Add(card);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = findDownCard; i < playableDownCard.Count; i++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
hand.Remove(playableDownCard[i]);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = findUpCard; i < playableUpCard.Count; i++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
hand.Remove(playableUpCard[i]);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
playableDownCard.ForEach(card => playableCard.Add(card));
|
|
|
|
|
|
|
|
playableUpCard.ForEach(card => playableCard.Add(card));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool played = false;
|
|
|
|
|
|
|
|
hand.ForEach(card =>
|
|
|
|
{
|
|
|
|
{
|
|
|
|
for (int i = 0; i < ListOrderedStacks.Size; i++)
|
|
|
|
for (int i = 0; i < ListOrderedStacks.Size; i++)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -40,17 +112,44 @@ namespace TheGameExtreme.model.gameActions.classic
|
|
|
|
if (card.Value > ListOrderedStacks.getStack(i).Peek().Value)
|
|
|
|
if (card.Value > ListOrderedStacks.getStack(i).Peek().Value)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
playableCard.Add(card);
|
|
|
|
playableCard.Add(card);
|
|
|
|
|
|
|
|
played = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (card.Value < ListOrderedStacks.getStack(i).Peek().Value)
|
|
|
|
else if (card.Value < ListOrderedStacks.getStack(i).Peek().Value)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
playableCard.Add(card);
|
|
|
|
playableCard.Add(card);
|
|
|
|
|
|
|
|
played = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 10) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 10) == 0)
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!played)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
for (int i = 0; i < playableDownCard.Count; i++)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
playableCard.Add(card);
|
|
|
|
if (card.Value > playableDownCard[i].Value)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
playableCard.Add(card);
|
|
|
|
|
|
|
|
played = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!played)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
for (int i = 0; i < playableUpCard.Count; i++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (card.Value < playableUpCard[i].Value)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
playableCard.Add(card);
|
|
|
|
|
|
|
|
played = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
played = false;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|