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); } }
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); }
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()); }