3 -export ([solve/0, solve/1]).
4 -compile ([export_all]).
12 io:format("The solution to ~p puzzle1 is: ~p~n", [?MODULE, solve(1)]);
16 io:format("The solution to ~p puzzle2 is: ~p~n", [?MODULE, solve(2)]);
21 {ok, IO} = file:open("input.txt", 'read'),
22 Ans = maybe_reduce(read_line(IO), IO),
27 {ok, IO} = file:open("input.txt", 'read'),
28 Numbers = read_all_lines(read_line(IO), IO, []),
30 io:format("total:~p lines: ~p~n", [length(Numbers), Numbers]),
31 max_magnitude(Numbers).
33 read_all_lines('eof', _IO, Acc) ->
35 read_all_lines(Line, IO, Acc) ->
36 read_all_lines(read_line(IO), IO, [Line|Acc]).
39 case file:read_line(IO) of
41 {ok, Tokens, _} = erl_scan:string(Line ++ "."),
42 {ok, Term} = erl_parse:parse_term(Tokens),
47 max_magnitude(Numbers) when is_list(Numbers) ->
48 lists:max([ max_magnitude(lists:split(I, Numbers)) || I <- lists:seq(1, length(Numbers))]);
49 max_magnitude({List1, List2}) ->
50 [H|T] = lists:reverse(List1),
51 max_magnitude(H, T ++ List2).
53 max_magnitude(Number, Rest) ->
54 lists:foldl(fun(N, MaxMag) ->
55 case magnitude(reduce([Number, N])) of
56 Mag when Mag > MaxMag -> Mag;
62 magnitude(A) when is_integer(A) -> A;
64 (3 * magnitude(A)) + (2 * magnitude(B)).
66 maybe_reduce(A, IO) ->
70 maybe_reduce(reduce([A,B]), IO)
74 case maybe_explode(N, 0) of
78 case maybe_split(N) of
86 maybe_explode([A,B], Depth) when Depth >= 4, is_integer(A), is_integer(B) ->
88 maybe_explode([A,B], Depth) ->
89 case maybe_explode(A, Depth+1) of
90 {true, New, AddA, AddB} ->
91 {true, [New, add_explode({b, AddB}, B)], AddA, 0};
93 case maybe_explode(B, Depth+1) of
94 {true, New, AddA, AddB} ->
95 {true, [add_explode({a, AddA}, A), New], 0, AddB};
100 maybe_explode(N, _) when is_integer(N) ->
103 add_explode({_, Add}, Num) when is_integer(Num) ->
105 add_explode({b, Add}, [A,B]) ->
106 [add_explode({b, Add}, A), B];
107 add_explode({a, Add}, [A,B]) ->
108 [A, add_explode({a,Add}, B)].
110 maybe_split(N) when is_integer(N) ->
114 Right = case Left*2 == N of true -> Left; false -> Left+1 end,
115 {true, [Left, Right]};
119 maybe_split([A, B]) ->
120 case maybe_split(A) of
124 case maybe_split(B) of