aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--permutations.lisp11
1 files changed, 11 insertions, 0 deletions
diff --git a/permutations.lisp b/permutations.lisp
index 4aa9640..d75a4d2 100644
--- a/permutations.lisp
+++ b/permutations.lisp
@@ -1,10 +1,12 @@
(defun mapcar-cons (e x)
+ (declare (xargs :guard (true-listp x)))
(if (endp x)
nil
(cons (cons e (car x))
(mapcar-cons e (cdr x)))))
(defun insert (e x)
+ (declare (xargs :guard (true-listp x)))
(if (endp x)
(list (list e))
(cons (cons e x)
@@ -12,47 +14,56 @@
(insert e (cdr x))))))
(defun mappend-insert (x y)
+ (declare (xargs :guard (true-list-listp y)))
(if (endp y)
nil
(append (insert x (car y))
(mappend-insert x (cdr y)))))
(defun permutations (x)
+ (declare (xargs :guard (true-listp x)))
(if (endp x)
(list nil)
(mappend-insert (car x)
(permutations (cdr x)))))
(defun factorial (n)
+ (declare (xargs :guard (natp n)))
(if (zp n)
1
(* n (factorial (1- n)))))
(defun mapcar-len (x)
+ (declare (xargs :guard (true-list-listp x)))
(if (endp x)
nil
(cons (len (car x))
(mapcar-len (cdr x)))))
(defun sum (x)
+ (declare (xargs :guard (nat-listp x)))
(if (endp x)
0
(+ (car x)
(sum (cdr x)))))
(defun mapcar-sum (x y)
+ (declare (xargs :guard (and (nat-listp x)
+ (nat-listp y))))
(if (or (endp x) (endp y))
nil
(cons (+ (car x) (car y))
(mapcar-sum (cdr x) (cdr y)))))
(defun repeat (x n)
+ (declare (xargs :guard (natp n)))
(if (zp n)
nil
(cons x
(repeat x (1- n)))))
(defun repeatedp (x)
+ (declare (xargs :guard (true-listp x)))
(if (or (endp x)
(endp (cdr x)))
t