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:
defmodule Day11 do
def part1(input) do
input
|> read_input()
|> compute_power_levels()
|> max_cell()
end
def part2(input) do
input
|> read_input()
|> compute_power_levels()
|> max_cell_dynamic_size()
end
defp read_input(input) do
input
|> File.read!()
end
defp compute_power_levels(input) do
serial_number = String.to_integer(input)
for x <- 1..300, y <- 1..300 do
rack_id = x + 10
power_level = (rack_id * y + serial_number) * rack_id
power_level =
if power_level > 100 do
power_level
|> to_string()
|> String.at(-3)
|> String.to_integer()
else
0
end
power_level = power_level - 5
{{x, y}, power_level}
end
|> Enum.into(%{})
end
defp max_cell(grid) do
for size <- 0..2 do
for x <- 1..(300 - size), y <- 1..(300 - size) do
power_level =
for xs <- 0..size, ys <- 0..size do
Map.get(grid, {x + xs, y + ys}) || 0
end
|> Enum.sum()
{power_level, {x, y}}
end
end
|> List.flatten()
|> Enum.max_by(fn {power_level, _} -> power_level end)
end
defp max_cell_dynamic_size(grid) do
acc = {{0, 0, 0}, 0}
Enum.reduce(1..299, acc, fn x, acc ->
Enum.reduce(1..299, acc, fn y, acc ->
find_largest(x, y, grid, acc)
end)
end)
end
defp find_largest(x, y, grid, acc) do
max_square_size = min(301 - x, 301 - y)
level = grid[{x, y}]
{best, _} =
Enum.reduce(2..max_square_size, {acc, level}, fn square_size,
{{_coord, prev_level} = prev, level} ->
level = sum_square(x, y, square_size, grid, level)
if level > prev_level do
{{{x, y, square_size}, level}, level}
else
{prev, level}
end
end)
best
end
defp sum_square(x0, y0, square_size, grid, acc) do
y = y0 + square_size - 1
acc =
Enum.reduce(x0..(x0 + square_size - 2), acc, fn x, acc ->
acc + grid[{x, y}]
end)
x = x0 + square_size - 1
acc =
Enum.reduce(y0..(y0 + square_size - 1), acc, fn y, acc ->
acc + grid[{x, y}]
end)
acc
end
end
# r Day11; :aoc2018 |> :code.priv_dir() |> Path.join("day11.txt") |> Day11.part1()
# :aoc2018 |> :code.priv_dir() |> Path.join("day11.txt") |> Day11.part2()
data:image/s3,"s3://crabby-images/893ce/893ce1b9a511233b885ffedbc2fb63f0bbbafe9b" alt="Simon Escobar Benitez"
ARTICLES: 8
Day 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 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