mirror of
https://github.com/correl/euler.git
synced 2024-11-27 11:09:54 +00:00
Exercise 004
This commit is contained in:
parent
625ee578b6
commit
5b86e3b132
1 changed files with 30 additions and 0 deletions
30
e004.erl
Normal file
30
e004.erl
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
% Find the largest palindrome made from the product of two 3-digit numbers.
|
||||||
|
|
||||||
|
% A palindromic number reads the same both ways. The largest palindrome made from the product of two 2-digit numbers is 9009 = 91 99.
|
||||||
|
% Find the largest palindrome made from the product of two 3-digit numbers.
|
||||||
|
|
||||||
|
-module(e004).
|
||||||
|
-export([
|
||||||
|
main/1
|
||||||
|
]).
|
||||||
|
|
||||||
|
product(Min, Max) ->
|
||||||
|
product(Min, Max, Max, Max, 0).
|
||||||
|
product(Min, _, N1, _, Product) when N1 < Min ->
|
||||||
|
Product;
|
||||||
|
product(Min, Max, N1, N2, Product) when N2 < Min ->
|
||||||
|
product(Min, Max, N1 - 1, Max, Product);
|
||||||
|
product(Min, Max, N1, N2, Product) ->
|
||||||
|
P = trunc(N1 * N2),
|
||||||
|
S = integer_to_list(trunc(N1 * N2)),
|
||||||
|
R = lists:reverse(S),
|
||||||
|
if
|
||||||
|
S == R, P > Product ->
|
||||||
|
product(Min, Max, N1, N2 - 1, P);
|
||||||
|
true ->
|
||||||
|
product(Min, Max, N1, N2 - 1, Product)
|
||||||
|
end.
|
||||||
|
|
||||||
|
main(_) ->
|
||||||
|
io:format("Largest palindrome product of 2-digit numbers: ~w~n", [product(10, 99)]),
|
||||||
|
io:format("Largest palindrome product of 3-digit numbers: ~w~n", [product(100, 999)]).
|
Loading…
Reference in a new issue