23 lines
609 B
Elixir
23 lines
609 B
Elixir
defmodule Digital do
|
|
def root(n, base\\10), do: root(n, base, 0)
|
|
|
|
defp root(n, base, ap) when n < base, do: {n, ap}
|
|
defp root(n, base, ap) do
|
|
Integer.digits(n, base) |> Enum.sum |> root(base, ap+1)
|
|
end
|
|
end
|
|
|
|
data = [627615, 39390, 588225, 393900588225]
|
|
Enum.each(data, fn n ->
|
|
{dr, ap} = Digital.root(n)
|
|
IO.puts "#{n} has additive persistence #{ap} and digital root of #{dr}"
|
|
end)
|
|
|
|
base = 16
|
|
IO.puts "\nBase = #{base}"
|
|
fmt = "~.#{base}B(#{base}) has additive persistence ~w and digital root of ~w~n"
|
|
Enum.each(data, fn n ->
|
|
{dr, ap} = Digital.root(n, base)
|
|
:io.format fmt, [n, ap, dr]
|
|
end)
|