1
1
mirror of https://github.com/kanaka/mal.git synced 2024-09-11 13:55:55 +03:00
mal/tests/computations.mal
Nicolas Boulenguez e6d41de4d5 load-file: accept empty file or final comment, return nil
Let `load-file` append a new line in case last line contains a
comment.

Also append `nil` so that the return value is predictible. Remove the
existing explicit `nil` from existing sources.

Adapt documentation and tests.
2019-07-28 13:08:05 +02:00

18 lines
502 B
Plaintext

;; Some inefficient arithmetic computations for benchmarking.
;; Unfortunately not yet available in tests of steps 4 and 5.
;; Compute n(n+1)/2 with a non tail-recursive call.
(def! sumdown
(fn* [n] ; non-negative number
(if (= n 0)
0
(+ n (sumdown (- n 1))))))
;; Compute a Fibonacci number with two recursions.
(def! fib
(fn* [n] ; non-negative number
(if (<= n 1)
n
(+ (fib (- n 1)) (fib (- n 2))))))