Exemple #1
0
        public string VisualizeGrid(int gridSize)
        {
            var sb = new StringBuilder();

            for (var y = 0; y < gridSize; y++)
            {
                for (var x = 0; x < gridSize; x++)
                {
                    if (OccupiedCoordinates.ContainsKey(y))
                    {
                        if (OccupiedCoordinates[y].Contains(x))
                        {
                            sb.Append('#');
                        }
                        else
                        {
                            sb.Append('.');
                        }
                    }
                    else
                    {
                        sb.Append('.');
                    }
                }

                sb.Append(Environment.NewLine);
            }

            return(sb.ToString());
        }
 private Coordinate CoordinateValidator(Coordinate coord)
 {
     if (!OccupiedCoordinates.Any(l => l.Contains(coord)))
     {
         return(coord);
     }
     else
     {
         MessageBox.Show("This coordinate choice is invalid!");
         return(null);
     }
 }
Exemple #3
0
        static void Main(string[] args)
        {
            var lines = File.ReadAllLines("input.txt");

            var wire1 = new OccupiedCoordinates(lines[0]);
            var wire2 = new OccupiedCoordinates(lines[1]);

            var intersectionCoords = wire1.Keys.Intersect(wire2.Keys);

            var closestDistance = intersectionCoords.Min(c => wire1[c] + wire2[c]);

            Console.WriteLine(closestDistance);
        }
Exemple #4
0
        private IEnumerable <Coordinate> CoordinateValidator(Coordinate coord)
        {
            List <Coordinate> returnCoords = new List <Coordinate>();

            if (!OccupiedCoordinates.Any(l => l.Contains(coord)))
            {
                returnCoords.Add(coord);
                return(returnCoords);
            }
            else
            {
                return(returnCoords);
            }
        }
        public int CountOverlaps(BlocksCollection b)
        {
            List <Vec> aOcc = OccupiedCoordinates.ToList();
            List <Vec> bOcc = b.OccupiedCoordinates.ToList();

            if (aOcc.Count() > bOcc.Count())
            {
                List <Vec> cOcc = aOcc;
                aOcc = bOcc;
                bOcc = cOcc;
            }
            HashSet <Vec> aSet = new HashSet <Vec>(aOcc);

            return(bOcc.Count(i => aSet.Contains(i)));
        }
 private void SetCoordinates(Ship ship, IEnumerable <Coordinate> coords)
 {
     ship.Placement.AddRange(coords);
     OccupiedCoordinates.Add(coords.ToList());
 }