|
|
|
@ -30,7 +30,80 @@ namespace TheGameExtreme.model.gameActions.decimals
|
|
|
|
|
|
|
|
|
|
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 + 1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 0.1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 0.01m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 0.001m) == 0)
|
|
|
|
|
{
|
|
|
|
|
playableDownCard.Add(card);
|
|
|
|
|
}
|
|
|
|
|
else if (card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 0.1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 0.01m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 0.001m) == 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 + 1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 0.1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 0.01m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 0.001m) == 0)
|
|
|
|
|
{
|
|
|
|
|
playableDownCard.Add(card);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
for (int i = 0; i < playableUpCard.Count; i++)
|
|
|
|
|
{
|
|
|
|
|
if (card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 0.1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 0.01m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 0.001m) == 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++)
|
|
|
|
|
{
|
|
|
|
@ -39,17 +112,44 @@ namespace TheGameExtreme.model.gameActions.decimals
|
|
|
|
|
if (card.Value > ListOrderedStacks.getStack(i).Peek().Value)
|
|
|
|
|
{
|
|
|
|
|
playableCard.Add(card);
|
|
|
|
|
played = true;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if (card.Value < ListOrderedStacks.getStack(i).Peek().Value)
|
|
|
|
|
{
|
|
|
|
|
playableCard.Add(card);
|
|
|
|
|
played = true;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else if (card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 0.1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 0.1m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 0.01m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 0.01m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value - 0.001m) == 0 || card.Value.CompareTo(ListOrderedStacks.getStack(i).Peek().Value + 0.001m) == 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;
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|