Last active
September 3, 2018 09:59
-
-
Save b0oh/bab249e123254c12ab9d257811ba1fb7 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| (let* ((true (lambda (true false) true)) | |
| (false (lambda (true false) false)) | |
| (and (lambda (pred1 pred2) (pred1 pred2 pred1))) | |
| (if (lambda (pred true-clause false-clause) (pred true-clause false-clause))) | |
| (fix (lambda (g) ((lambda (x) (g (x x))) (lambda (x) (g (x x)))))) | |
| (pair (lambda (first second pair) (pair first second))) | |
| (first (lambda (pair) (pair true))) | |
| (second (lambda (pair) (pair false))) | |
| (0 (lambda (succ zero) zero)) | |
| (inc (lambda (num succ zero) (succ (num succ zero)))) | |
| (+ (lambda (num1 num2 succ zero) (num1 succ (num2 succ zero)))) | |
| (* (lambda (num1 num2 succ zero) (num1 (num2 succ) zero))) | |
| (paired-inc (lambda (num) (pair (second num) (inc (second num))))) | |
| (dec (lambda (num) (first (num paired-inc (pair 0 0))))) | |
| (- (lambda (num1 num2) (num2 dec num1))) | |
| (0? (lambda (num) (num (lambda (_) false) true))) | |
| (leq? (lambda (num1 num2) (0? (- num1 num2)))) | |
| (eq? (lambda (num1 num2) (and (leq? num1 num2) (leq? num2 num1)))) | |
| (1 (inc 0)) | |
| (2 (+ 1 1)) | |
| (4 (* 2 2)) | |
| (fac (fix (lambda (fac num) | |
| (if (eq? num 0) | |
| 1 | |
| (* num (fac (- num 1)))))))) | |
| (fac (+ 1 4)) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment