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:
defmodule Day3 do
@grid_info ~r/#(\d+) @ (\d+),(\d+): (\d+)x(\d+)/
def part1(input) do
{overlaps, _} =
input
|> read_input()
|> extract_grid()
|> build_map()
|> Enum.reduce({MapSet.new(), MapSet.new()}, fn {x, y, _id}, {overlap, no_overlap} ->
if MapSet.member?(no_overlap, {x, y}) do
{MapSet.put(overlap, {x, y}), no_overlap}
else
{overlap, MapSet.put(no_overlap, {x, y})}
end
end)
MapSet.size(overlaps)
end
def part2(input) do
map =
input
|> read_input()
|> extract_grid()
|> build_keyed_map()
{id, _} =
for {id1, coordinates1} <- map,
{id2, coordinates2} <- map,
id1 != id2 do
overlaps = MapSet.intersection(coordinates1, coordinates2)
if MapSet.size(overlaps) != 0 do
{id1, id2}
else
{id1, nil}
end
end
|> Enum.group_by(fn {key, _} -> key end, fn {_, value} -> value end)
|> Enum.find(fn {_key, overlaps} ->
Enum.all?(overlaps, &Kernel.==(&1, nil))
end)
id
end
defp read_input(input) do
input
|> File.read!()
|> String.split("\n", trim: true)
end
defp extract_grid(lines) do
Enum.map(lines, fn line ->
[id, x, y, width, height] = Regex.run(@grid_info, line, capture: :all_but_first)
[
id,
String.to_integer(x),
String.to_integer(y),
String.to_integer(width),
String.to_integer(height)
]
end)
end
defp build_map(grid) do
Enum.flat_map(grid, fn [id, x, y, width, height] ->
for x <- x..(x + width - 1),
y <- y..(y + height - 1) do
{x, y, id}
end
end)
end
defp build_keyed_map(grid) do
Enum.reduce(grid, %{}, fn [id, x, y, width, height], acc ->
coordinates =
for x <- x..(x + width - 1),
y <- y..(y + height - 1) do
{x, y}
end
Map.put_new(acc, id, MapSet.new(coordinates))
end)
end
end
# :aoc2018 |> :code.priv_dir() |> Path.join("day3.txt") |> Day3.part1()
# :aoc2018 |> :code.priv_dir() |> Path.join("day3.txt") |> Day3.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 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 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