avent modif algo recherche ter

This commit is contained in:
adri 2018-05-21 15:08:46 +02:00
parent 21010009b5
commit 75f9c1c57c
5 changed files with 253 additions and 50 deletions

View File

@ -15,6 +15,15 @@ namespace go01
public Form Fenetre; public Form Fenetre;
public int dim; public int dim;
Label LabelPlayerTurn; Label LabelPlayerTurn;
struct carrefour_S
{
public Point pointCourant, pointSuivant;
public carrefour_S(Point pointCourant, Point pointSuivant)
{
this.pointCourant = pointCourant;
this.pointSuivant = pointSuivant;
}
}
string playerWName, playerBName; string playerWName, playerBName;
enum Occupant_E { Vide, Blanc, Noir, LAST} enum Occupant_E { Vide, Blanc, Noir, LAST}
public enum Joueur_E { Blanc, Noir, LAST} public enum Joueur_E { Blanc, Noir, LAST}
@ -119,33 +128,39 @@ namespace go01
PictureBox pb = (PictureBox)sender; PictureBox pb = (PictureBox)sender;
String[] xy = ((PictureBox)sender).Name.Split(';'); String[] xy = ((PictureBox)sender).Name.Split(';');
Console.WriteLine($"{xy[0]};{xy[1]}"); Console.WriteLine($"{xy[0]};{xy[1]}");
if (tableauOccupation[int.Parse(xy[0]), int.Parse(xy[1])] == Occupant_E.Vide) if (tableauOccupation[int.Parse(xy[0]), int.Parse(xy[1])] == Occupant_E.Vide)
{ {
tableauOccupation[int.Parse(xy[0]), int.Parse(xy[1])] = (Tour == Joueur_E.Blanc) ? Occupant_E.Blanc : Occupant_E.Noir; tableauOccupation[int.Parse(xy[0]), int.Parse(xy[1])] = (Tour == Joueur_E.Blanc) ? Occupant_E.Blanc : Occupant_E.Noir;
Tour = (Tour+1 == Joueur_E.LAST) ? Joueur_E.Blanc : Tour+1; //Tour = (Tour+1 == Joueur_E.LAST) ? Joueur_E.Blanc : Tour+1;
} using (Graphics gr = Graphics.FromHwnd((pb.Handle)))
using (Graphics gr = Graphics.FromHwnd((pb.Handle)))
{
SolidBrush b = null;
switch(tableauOccupation[int.Parse(xy[0]), int.Parse(xy[1])])
{ {
case Occupant_E.Blanc: SolidBrush b = null;
b = new SolidBrush(Color.White); switch (tableauOccupation[int.Parse(xy[0]), int.Parse(xy[1])])
break; {
case Occupant_E.Noir: case Occupant_E.Blanc:
b = new SolidBrush(Color.Black); b = new SolidBrush(Color.White);
break; break;
case Occupant_E.Vide: case Occupant_E.Noir:
b = null; b = new SolidBrush(Color.Black);
break; break;
case Occupant_E.Vide:
b = null;
break;
}
if (b != null)
gr.FillEllipse(b, 1, 0, pb.ClientSize.Width - 2, pb.ClientSize.Height - 1);
else
gr.DrawImage(pb.Image, 0, 0, pb.Width, pb.Height);
} }
if (b != null)
gr.FillEllipse(b, 1,0, pb.ClientSize.Width-2, pb.ClientSize.Height-1); RechercheTeritoir(int.Parse(xy[0]), int.Parse(xy[1]));
else
gr.DrawImage(pb.Image, 0, 0, pb.Width, pb.Height);
} }
} }
private int[] GetXY(int i) private int[] GetXY(int i)
{ {
@ -167,47 +182,235 @@ namespace go01
void RechercheTeritoir(int x, int y) void RechercheTeritoir(int x, int y)
{ {
List<Point> carrefour = new List<Point>(); List<carrefour_S> carrefour = new List<carrefour_S>();
Point origine = new Point(x, y);
Point pointCourant = new Point(x, y); Point pointCourant = new Point(x, y);
Point pointPrecedent; Point pointSuivant, pointPrec;
Point min = new Point(x, y), max = new Point(x, y); Point min = new Point(x, y), max = new Point(x, y);
bool[,] tmpParcour = new bool[dim, dim];
tmpParcour[origine.X, origine.Y] = true;
pointSuivant = RecherchePointSuivant(pointCourant, new Point(-1,-1), tmpParcour, carrefour);
pointPrec = pointCourant;
pointCourant = pointSuivant;
if (pointSuivant.X != -1)
{
tmpParcour[pointCourant.X, pointCourant.Y] = true;
while ((pointSuivant = RecherchePointSuivant(pointCourant, pointPrec, tmpParcour, carrefour)).X != -1 || carrefour.Count > 0)
{
using (Graphics gr = Graphics.FromHwnd((pboxList[xyToi(pointCourant.X, pointCourant.Y)].Handle)))
{
SolidBrush b = new SolidBrush(Color.Red);
if (b != null)
gr.FillEllipse(b, 1, 0, pboxList[xyToi(pointCourant.X, pointCourant.Y)].ClientSize.Width - 2, pboxList[xyToi(pointCourant.X, pointCourant.Y)].ClientSize.Height - 1);
else
gr.DrawImage(pboxList[xyToi(pointCourant.X, pointCourant.Y)].Image, 0, 0, pboxList[xyToi(pointCourant.X, pointCourant.Y)].Width, pboxList[xyToi(pointCourant.X, pointCourant.Y)].Height);
}
foreach(carrefour_S c in carrefour)
{
using (Graphics gr = Graphics.FromHwnd((pboxList[xyToi(c.pointSuivant.X, c.pointSuivant.Y)].Handle)))
{
SolidBrush b = new SolidBrush(Color.Orange);
if (b != null)
gr.FillEllipse(b, 1, 0, pboxList[xyToi(c.pointSuivant.X, c.pointSuivant.Y)].ClientSize.Width - 2, pboxList[xyToi(c.pointSuivant.X, c.pointSuivant.Y)].ClientSize.Height - 1);
else
gr.DrawImage(pboxList[xyToi(pointCourant.X, pointCourant.Y)].Image, 0, 0, pboxList[xyToi(pointCourant.X, pointCourant.Y)].Width, pboxList[xyToi(pointCourant.X, pointCourant.Y)].Height);
}
}
System.Threading.Thread.Sleep(500);
Console.WriteLine("Debut Boucle");
printTab(tmpParcour);
if (pointSuivant.X == -1)
{
pointSuivant = new Point(carrefour[carrefour.Count - 1].pointSuivant.X, carrefour[carrefour.Count - 1].pointSuivant.Y);
tmpParcour[pointSuivant.X, pointSuivant.Y] = true;
pointPrec = new Point(carrefour[carrefour.Count - 1].pointCourant.X, carrefour[carrefour.Count - 1].pointCourant.Y);
pointCourant = pointSuivant;
carrefour.RemoveAt(carrefour.Count - 1);
}
else if (tmpParcour[pointSuivant.X, pointSuivant.Y] || ptEgal(pointSuivant, pointPrec))
{
if (carrefour.Count > 0 && !ptEgal(pointSuivant, origine))
{
pointSuivant = new Point(carrefour[carrefour.Count - 1].pointSuivant.X, carrefour[carrefour.Count - 1].pointSuivant.Y);
tmpParcour[pointSuivant.X, pointSuivant.Y] = true;
pointPrec = new Point(carrefour[carrefour.Count - 1].pointCourant.X, carrefour[carrefour.Count - 1].pointCourant.Y);
pointCourant = pointSuivant;
carrefour.RemoveAt(carrefour.Count - 1);
if (ptEgal(pointSuivant, origine))
break;
}
else if (ptEgal(pointSuivant, origine))
{
Console.WriteLine("teritoir trouver");
printTab(tmpParcour);
break;
}
else
{
Console.WriteLine("teritoir non trouver");
printTab(tmpParcour);
break;
}
}
else
{
tmpParcour[pointSuivant.X, pointSuivant.Y] = true;
pointPrec = pointCourant;
pointCourant = pointSuivant;
}
printTab(tmpParcour);
}
redrawAllpb();
}
} }
Point RecherchePointSuivant(Point p, ref List<Point> carrefour) Point RecherchePointSuivant(Point p, Point ptPrec, bool[,] parcout, List<carrefour_S> carrefour)
{ {
Occupant_E occupant = (Tour == Joueur_E.Blanc)?Occupant_E.Blanc:Occupant_E.Noir;
bool trouver = false; bool trouver = false;
if () Point pRet = new Point(-1, -1);
if (tableauOccupation[p.X,p.Y-1] == occupant)
{ {
if(trouver && !parcout[p.X,p.Y-1])
carrefour.Add(new carrefour_S(new Point(p.X,p.Y), new Point(p.X,p.Y-1)));
else if(!ptEgal(ptPrec, new Point(p.X,p.Y-1)))
{
pRet = new Point(p.X,p.Y-1);
trouver = true;
}
} }
if () if (tableauOccupation[p.X+1,p.Y-1] == occupant)
{ {
if(trouver && !parcout[p.X+1,p.Y-1])
carrefour.Add(new carrefour_S(new Point(p.X, p.Y), new Point(p.X+1,p.Y-1)));
else if(!ptEgal(ptPrec, new Point(p.X+1,p.Y-1)))
{
pRet = new Point(p.X+1,p.Y-1);
trouver = true;
}
} }
if () if (tableauOccupation[p.X+1,p.Y] == occupant)
{ {
if(trouver && !parcout[p.X+1,p.Y])
carrefour.Add(new carrefour_S(new Point(p.X, p.Y), new Point(p.X+1,p.Y)));
else if(!ptEgal(ptPrec, new Point(p.X+1,p.Y)))
{
pRet = new Point(p.X+1,p.Y);
trouver = true;
}
} }
if () if (tableauOccupation[p.X+1,p.Y+1] == occupant)
{ {
if(trouver && !parcout[p.X+1,p.Y+1])
carrefour.Add(new carrefour_S(new Point(p.X, p.Y), new Point(p.X+1,p.Y+1)));
else if(!ptEgal(ptPrec, new Point(p.X+1,p.Y+1)))
{
pRet = new Point(p.X+1,p.Y+1);
trouver = true;
}
} }
if () if (tableauOccupation[p.X,p.Y+1] == occupant)
{ {
if(trouver && !parcout[p.X,p.Y+1])
carrefour.Add(new carrefour_S(new Point(p.X, p.Y), new Point(p.X,p.Y+1)));
else if(!ptEgal(ptPrec, new Point(p.X,p.Y+1)))
{
pRet = new Point(p.X,p.Y+1);
trouver = true;
}
} }
if () if (tableauOccupation[p.X-1,p.Y+1] == occupant)
{ {
if(trouver && !parcout[p.X-1,p.Y+1])
carrefour.Add(new carrefour_S(new Point(p.X, p.Y), new Point(p.X-1,p.Y+1)));
else if(!ptEgal(ptPrec, new Point(p.X-1,p.Y+1)))
{
pRet = new Point(p.X-1,p.Y+1);
trouver = true;
}
} }
if () if (tableauOccupation[p.X-1,p.Y] == occupant)
{ {
if(trouver && !parcout[p.X-1,p.Y])
carrefour.Add(new carrefour_S(new Point(p.X, p.Y), new Point(p.X-1,p.Y)));
else if(!ptEgal(ptPrec, new Point(p.X-1,p.Y)))
{
pRet = new Point(p.X-1,p.Y);
trouver = true;
}
} }
if () if (tableauOccupation[p.X-1,p.Y-1] == occupant)
{ {
if(trouver && !parcout[p.X-1,p.Y-1])
carrefour.Add(new carrefour_S(new Point(p.X, p.Y), new Point(p.X-1,p.Y-1)));
else if(!ptEgal(ptPrec, new Point(p.X-1,p.Y-1)))
{
pRet = new Point(p.X-1,p.Y-1);
trouver = true;
}
}
return pRet;
}
Boolean ptEgal(Point pt1, Point pt2)
{
return pt1.X == pt2.X && pt1.Y == pt2.Y;
}
void printTab(bool[,] Tab)
{
for(int y = 0;y<dim;y++)
{
for (int x = 0; x < dim; x++)
{
Console.ForegroundColor = Tab[x, y] ? ConsoleColor.Green : ConsoleColor.White;
Console.Write(Tab[x, y] ? '1' : '0');
}
Console.WriteLine();
}
Console.WriteLine();
Console.WriteLine();
Console.WriteLine();
}
int xyToi(int x, int y)
{
return x + dim* y;
}
void redrawAllpb()
{
for(int i=0;i<dim*dim;i++)
{
if (tableauOccupation[GetX(i), GetY(i)] != Occupant_E.Vide)
{
//Tour = (Tour+1 == Joueur_E.LAST) ? Joueur_E.Blanc : Tour+1;
using (Graphics gr = Graphics.FromHwnd((pboxList [i].Handle)))
{
SolidBrush b = null;
switch (tableauOccupation[GetX(i), GetY(i)])
{
case Occupant_E.Blanc:
b = new SolidBrush(Color.White);
break;
case Occupant_E.Noir:
b = new SolidBrush(Color.Black);
break;
case Occupant_E.Vide:
b = null;
break;
}
if (b != null)
gr.FillEllipse(b, 1, 0, pboxList[i].ClientSize.Width - 2, pboxList[i].ClientSize.Height - 1);
else
gr.DrawImage(pboxList[i].Image, 0, 0, pboxList[i].Width, pboxList[i].Height);
}
}
} }
return p;
} }
} }
} }

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.