Day 8: Memory maneuver - Advent of Code
Stavros Aronis
08.12.2018
I did the Advent of Code 2018 day 8 challenge in Erlang! Parts one and two are as follows:
#!/usr/bin/env escript
-mode(native).
%% https://adventofcode.com/2018/day/8
main(Args) ->
[Input] = read_input(),
Sol =
case Args of
["2"] -> value([Input], [1]);
_ -> sum_metadata([Input])
end,
io:format("~p~n", [Sol]).
read_input() ->
read_input(1).
read_input(0) -> [];
read_input(Nodes) ->
{ok, [ChildrenCount, MetaCount]} = io:fread("", "~d ~d"),
Children = read_input(ChildrenCount),
ReadMeta =
fun() ->
{ok, [M]} = io:fread("", "~d"),
M
end,
Meta = [ReadMeta() || _ <- lists:seq(1, MetaCount)],
Rest = read_input(Nodes - 1),
[{Children, Meta} | Rest].
sum_metadata([]) -> 0;
sum_metadata([{Children, Meta}|Rest]) ->
A = sum_metadata(Rest),
B = sum_metadata(Children),
C = lists:sum(Meta),
A + B + C.
value([], Meta) ->
lists:sum(Meta);
value(Children, Which) ->
Marked = select(Which, Children),
lists:sum([value(C, M) || {C, M} <- Marked]).
select(Which, Children) ->
select(Which, Children, []).
select([], _, Acc) ->
Acc;
select([N|R], Children, Acc) ->
try
C = lists:nth(N, Children),
select(R, Children, [C|Acc])
catch
_:_ ->
select(R, Children, Acc)
end.
data:image/s3,"s3://crabby-images/f3bd3/f3bd303b1dc3240d6f983983e5c700a77e4847e6" alt="Stavros Aronis"
ARTICLES: 6
Day 18: Settlers of The North Pole - Advent of Code 2018
data:image/s3,"s3://crabby-images/61d27/61d2718215cb08fc9b93398b45073048fc3caff4" alt="Day 18: Settlers of The North Pole - Advent of Code 2018"
Article by Stavros Aronis
I did the Advent of Code 2018 day 18 challenge in Erlang! Parts one and two are as follows:
READ MOREDay 14: Chocolate Charts - Advent of Code 2018
data:image/s3,"s3://crabby-images/dd4fb/dd4fb80c2ef92abe7faed7675c04571ba2666901" alt="Day 14: Chocolate Charts - Advent of Code 2018"
Article by Stavros Aronis
I did the Advent of Code 2018 day 14 challenge in Erlang! Parts one and two are as follows:
READ MOREDay 13: Mine Cart Madness - Advent of Code 2018
data:image/s3,"s3://crabby-images/ffaf8/ffaf871df18a1f15a16d79e389ff0fd1644a22d7" alt="Day 13: Mine Cart Madness - Advent of Code 2018"
Article by Stavros Aronis
I did the Advent of Code 2018 day 13 challenge in Erlang! Parts one and two are as follows:
READ MOREDay 12: Subterranean Sustainability - Advent of Code 2018
data:image/s3,"s3://crabby-images/13445/134457a58af4a04fbd30660a6946ea2471ebfff7" alt="Day 12: Subterranean Sustainability - Advent of Code 2018"
Article by Stavros Aronis
I did the Advent of Code 2018 day 12 challenge in Erlang! Parts one and two are as follows:
READ MOREDay 9: Marble Mania - Advent of Code 2018
data:image/s3,"s3://crabby-images/81385/81385c49339116961b74bcf09b84a8a89ebe581f" alt="Day 9: Marble Mania - Advent of Code 2018"
Article by Stavros Aronis
I did the Advent of Code 2018 day 9 challenge in Erlang! Parts one and two are as follows:
READ MORE