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:
defmodule Day10 do
def part1(input) do
{grid, _times} =
input
|> read_input()
|> parse_input()
|> iter()
draw(grid)
end
def part2(input) do
{_grid, times} =
input
|> read_input()
|> parse_input()
|> iter()
times
end
defp read_input(input) do
input
|> File.read!()
|> String.split("\n", trim: true)
end
defp parse_input(input) do
Enum.map(input, fn line ->
[x, y, vx, vy] =
Regex.scan(~r/(-?\d+)/, line, capture: :all_but_first)
|> List.flatten()
|> Enum.map(&String.to_integer/1)
{{x, y}, {vx, vy}}
end)
end
defp iter(grid) do
distance =
grid
|> layout()
|> distance()
iter(grid, distance, 0)
end
defp iter(grid, previous_distance, times) do
new_grid =
Enum.map(grid, fn {{x, y}, {vx, vy} = v} ->
{{x + vx, y + vy}, v}
end)
distance =
new_grid
|> layout()
|> distance()
if distance <= previous_distance do
iter(new_grid, distance, times + 1)
else
{grid, times}
end
end
defp layout(grid) do
Enum.reduce(grid, {0, 0, 0, 0}, fn {{x, _}, _}, {min_x, max_x, min_y, max_y} ->
{
Enum.min([min_x, x]),
Enum.max([max_x, x]),
Enum.min([min_y, x]),
Enum.max([max_y, x])
}
end)
end
defp distance({min_x, max_x, min_y, max_y}) do
abs(max_x - min_x) + abs(max_y - min_y)
end
defp draw(grid) do
grid =
grid
|> Enum.map(&{elem(&1, 0), 0})
|> Enum.into(%{})
{min_x, max_x, min_y, max_y} = layout(grid)
for y <- min_y..max_y do
for x <- min_x..max_x do
if Map.get(grid, {x, y}) do
IO.write("#")
else
IO.write(".")
end
end
IO.write("\n")
end
grid
end
end
# r Day10; :aoc2018 |> :code.priv_dir() |> Path.join("day10.txt") |> Day10.part1()
# r Day10; :aoc2018 |> :code.priv_dir() |> Path.join("day10.txt") |> Day10.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 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 6: Chronal Coordinates - Advent of Code 2018
data:image/s3,"s3://crabby-images/7abc2/7abc2ea1387965449fec3d110963c1a1f18b1a2e" alt="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:
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