Day 6: Chronal Coordinates - Advent of Code 2018
I did the Advent of Code 2018 day 6 challenge in Elixir! Parts one and two are as follows:
defmodule Day6 do
def part1(input) do
{_infinites, finites} =
input
|> read_input()
|> create_grid()
|> group_by_infinites()
{_coordinates, layout} =
finites
|> Enum.group_by(fn {x, y, _dist} -> {x, y} end)
|> Enum.max_by(fn {_, v} -> length(v) end)
length(layout)
end
def part2(input) do
{max_x, max_y, coordinates} =
input
|> read_input()
for x <- 0..max_x,
y <- 0..max_y do
coordinates
|> Enum.reduce(0, fn {point_x, point_y}, acc ->
distance = abs(x - point_x) + abs(y - point_y)
distance + acc
end)
end
|> Enum.filter(&(&1 < 10_000))
|> Enum.count()
end
defp read_input(input) do
{max_x, max_y, coordinates} =
input
|> File.read!()
|> String.trim()
|> String.split("\n", trim: true)
|> Enum.reduce({-1, -1, []}, fn line, {max_x, max_y, coordinates} ->
[x, y] = String.split(line, ", ")
x = String.to_integer(x)
y = String.to_integer(y)
coordinate = {x, y}
max_x = if x > max_x, do: x, else: max_x
max_y = if y > max_y, do: y, else: max_y
{max_x, max_y, [coordinate | coordinates]}
end)
{max_x, max_y, Enum.reverse(coordinates)}
end
defp create_grid({max_x, max_y, coordinates}) do
for x <- 0..max_x,
y <- 0..max_y do
[{px, py, dist1}, {_, _, dist2} | _] =
Enum.map(coordinates, fn {point_x, point_y} ->
distance = abs(x - point_x) + abs(y - point_y)
{point_x, point_y, distance}
end)
|> Enum.sort_by(fn {_, _, distance} -> distance end)
if dist1 == dist2 do
nil
else
cond do
x == 0 ->
{:infinite, px, py}
x == max_x ->
{:infinite, px, py}
y == 0 ->
{:infinite, px, py}
y == max_y ->
{:infinite, px, py}
true ->
{px, py, dist1}
end
end
end
end
defp group_by_infinites(grid) do
Enum.reduce(grid, {MapSet.new(), []}, fn
nil, acc ->
acc
{:infinite, px, py}, {infinites, finites} ->
{MapSet.put(infinites, {px, py}), finites}
{px, py, dist}, {infinites, finites} ->
if MapSet.member?(infinites, {px, py}) do
{infinites, finites}
else
{infinites, [{px, py, dist} | finites]}
end
end)
end
end
# r Day6; :aoc2018 |> :code.priv_dir() |> Path.join("day6.txt") |> Day6.part1()
# r Day6; :aoc2018 |> :code.priv_dir() |> Path.join("day6.txt") |> Day6.part2()
data:image/s3,"s3://crabby-images/893ce/893ce1b9a511233b885ffedbc2fb63f0bbbafe9b" alt="Simon Escobar Benitez"
ARTICLES: 8
Day 11: Chronal Charge - Advent of Code 2018
data:image/s3,"s3://crabby-images/4f71b/4f71b82755c72e858a4be406d4764e593176f894" alt="Day 11: Chronal Charge - Advent of Code 2018"
I did the Advent of Code 2018 day 11 challenge in Elixir! Parts one and two are as follows:
READ MOREDay 10: The Stars Align - Advent of Code 2018
data:image/s3,"s3://crabby-images/a57bc/a57bcf553c0ff1212b3142834abfd12f96c050b4" alt="Day 10: The Stars Align - Advent of Code 2018"
I did the Advent of Code 2018 day 10 challenge in Elixir! Parts one and two are as follows:
READ MOREDay 7: The Sum of Its Parts - Advent of Code 2018
data:image/s3,"s3://crabby-images/11692/11692249d62faa4956225a29d604ccdbd5a430bc" alt="Day 7: The Sum of Its Parts - Advent of Code 2018"
I did the Advent of Code 2018 day 7 challenge in Elixir! Parts one and two are as follows:
READ MOREDay 5: Alchemical Reduction - Advent of Code 2018
data:image/s3,"s3://crabby-images/03732/03732a3ad9325674170c9238c0ec186d79d66502" alt="Day 5: Alchemical Reduction - Advent of Code 2018"
I did the Advent of Code 2018 day 5 challenge in Elixir! Parts one and two are as follows:
READ MOREDay 4: Repose Record - Advent of Code 2018
data:image/s3,"s3://crabby-images/5b89f/5b89f57cf8236296547d478bcf9bc4d52bc03b9a" alt="Day 4: Repose Record - Advent of Code 2018"
I did the Advent of Code 2018 day 4 challenge in Elixir! Parts one and two are as follows:
READ MOREDay 3: No matter how you slice it - Advent of Code 2018
data:image/s3,"s3://crabby-images/5067f/5067f550862a56cc64d0bbeb19f2a25632d3078b" alt="Day 3: No matter how you slice it - Advent of Code 2018"
I did the Advent of Code 2018 day 3 challenge in Elixir! Parts one and two are as follows:
READ MOREDay 2: Inventory Management System - Advent of Code 2018
data:image/s3,"s3://crabby-images/2902d/2902d22b2451d374b54dabfcf0f29fe274651fe8" alt="Day 2: Inventory Management System - Advent of Code 2018"
I did the Advent of Code 2018 day 2 challenge in Elixir! Parts one and two are as follows:
READ MOREDay 1: Chronal Calibration - Advent of Code 2018
data:image/s3,"s3://crabby-images/98ae5/98ae556b504818553b39cdbac7c0ddd20907c7d5" alt="Day 1: Chronal Calibration - Advent of Code 2018"
Advent of Code 2018 - Day 1 solution in Elixir! #AdventOfBEAM
READ MORE