day06: Day 06: Chronal Coordinates

Description Usage Arguments Details Value Note Examples

Description

Chronal Coordinates

Usage

1
2
3
4
5
6
7
8
9

Arguments

lines

character vector with problem input. Each string in the vector should a be coordinate.

df_beacons

a dataframe created by read_beacon_coordinates()

pad

integer indicating how far north, east, south, west of the beacons to go when making the grid.

area_grid

a matrix created by search_grid_around_beacons()

threshold

a point is safe when the total distance between the point and all the beacons is less than the threshold

safe_grid

a matrix created by search_grid_for_safe_regions()

Details

Part One

The device on your wrist beeps several times, and once again you feel like you're falling.

"[Situation critical]title="Why is the situation always critical? Why can't the situation just be boring for once?"," the device announces. "Destination indeterminate. Chronal interference detected. Please specify new target coordinates."

The device then produces a list of coordinates (your puzzle input). Are they places it thinks are safe or dangerous? It recommends you check manual page 729. The Elves did not give you a manual.

If they're dangerous, maybe you can minimize the danger by finding the coordinate that gives the largest distance from the other points.

Using only the Manhattan distance, determine the area around each coordinate by counting the number of integer X,Y locations that are closest to that coordinate (and aren't tied in distance to any other coordinate).

Your goal is to find the size of the largest area that isn't infinite. For example, consider the following list of coordinates:

1
2
3
4
5
6
1, 1
1, 6
8, 3
3, 4
5, 5
8, 9

If we name these coordinates A through F, we can draw them on a grid, putting 0,0 at the top left:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
..........
.A........
..........
........C.
...D......
.....E....
.B........
..........
..........
........F.

This view is partial - the actual grid extends infinitely in all directions. Using the Manhattan distance, each location's closest coordinate can be determined, shown here in lowercase:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
aaaaa.cccc
aAaaa.cccc
aaaddecccc
aadddeccCc
..dDdeeccc
bb.deEeecc
bBb.eeee..
bbb.eeefff
bbb.eeffff
bbb.ffffFf

Locations shown as . are equally far from two or more coordinates, and so they don't count as being closest to any.

In this example, the areas of coordinates A, B, C, and F are infinite - while not shown here, their areas extend forever outside the visible grid. However, the areas of coordinates D and E are finite: D is closest to 9 locations, and E is closest to 17 (both including the coordinate's location itself). Therefore, in this example, the size of the largest area is 17.

What is the size of the largest area that isn't infinite?

Part Two

On the other hand, if the coordinates are safe, maybe the best you can do is try to find a region near as many coordinates as possible.

For example, suppose you want the sum of the Manhattan distance to all of the coordinates to be less than 32. For each location, add up the distances to all of the given coordinates; if the total of those distances is less than 32, that location is within the desired region. Using the same coordinates as above, the resulting region looks like this:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
..........
.A........
..........
...###..C.
..#D###...
..###E#...
.B.###....
..........
..........
........F.

In particular, consider the highlighted location 4,3 located at the top middle of the region. Its calculation is as follows, where abs() is the absolute value function:

Because the total distance to all coordinates (30) is less than 32, the location is within the region.

This region, which also includes coordinates D and E, has a total size of 16.

Your actual region will need to be much larger than this example, though, instead including all locations with a total distance of less than 10000.

What is the size of the region containing all locations which have a total distance to all given coordinates of less than 10000?

Value

For Part One, read_beacon_coordinates(lines) returns a dataframe with the problem input. search_grid_around_beacons(df_beacon) returns a matrix of the grid described by the problem input. The value of each cell is the labels of the nearest beacon or "." in the case of ties. measure_finite_beacon_areas(area_grid) returns a list of the beacon-areas. The keys (names) in the list are the labels of the beacons and the values are the finite areas.... For Part Two, search_grid_for_safe_regions(df_beacon, threshold) returns a matrix of the grid described by the problem input. The cell is in the safe region if its value is "#". Otherwises, its value is ".". measure_safe_area(safe_grid) returns a list with the size of the "#" in the grid.

Note

I call the "coordinates" beacons to clarify my conceptualization of the problem.

Examples

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
lines <- "
  1, 1
  1, 6
  8, 3
  3, 4
  5, 5
  8, 9"

df <- lines %>%
  read_text_lines() %>%
  read_beacon_coordinates()

# Match labels of description
df$label <- LETTERS[as.integer(df$label)]

grid <- search_grid_around_beacons(df)
measure_finite_beacon_areas(grid)

safe_grid <- search_grid_for_safe_regions(df, 32)
safe_grid

measure_safe_area(safe_grid)

tjmahr/adventofcode18 documentation built on May 24, 2019, 4:10 p.m.