aboutsummaryrefslogtreecommitdiff
path: root/entries/s-lando/fib.ex
blob: fae4d3c9d7a531a545265a77895a8aa0f29bfd18 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
defmodule Fib do
  # elegant
  def fib(n) when n < 2, do: n
  def fib(n), do: fib(n - 1) + fib(n - 2)

  
  # less elegant
  def fib2(n) do
    fib2(n, 0, 1)
  end

  def fib2(n, current, next) do
    cond do
      n == 0 -> current
      n == 1 -> next
      true -> fib2(n - 1, next, current + next)
    end
  end
  
end