Implement TCO for cons cell toString
This commit is contained in:
parent
e8e9d2e12d
commit
efb0329fda
11
lisp/tail/length-recursion.lisp
Normal file
11
lisp/tail/length-recursion.lisp
Normal file
@ -0,0 +1,11 @@
|
||||
(load "../lang/functions.lisp")
|
||||
|
||||
(defun build (n lst)
|
||||
(if (= n 0) lst
|
||||
(build (- n 1) (cons (car lst) lst))))
|
||||
|
||||
(defun build2 (n lst)
|
||||
(if (= n 0) lst
|
||||
(build2 (- n 1) (build 200 lst))))
|
||||
|
||||
(length (build2 200 (build2 200 (build2 200 (build2 200 '(1 1 1 1 0 0 0 0))))))
|
@ -8,4 +8,4 @@
|
||||
(if (= n 0) lst
|
||||
(build2 (- n 1) (build 200 lst))))
|
||||
|
||||
(length (build2 200 (build2 200 '(1 1 1 1 0 0 0 0))))
|
||||
(build2 200 (build2 200 (build2 200 (build2 200 '(1 1 1 1 0 0 0 0)))))
|
@ -1,5 +1,10 @@
|
||||
package sexpression;
|
||||
|
||||
import static recursion.tail.TailCalls.done;
|
||||
import static recursion.tail.TailCalls.tailCall;
|
||||
|
||||
import recursion.tail.TailCall;
|
||||
|
||||
@DisplayName("list")
|
||||
public class Cons extends SExpression {
|
||||
|
||||
@ -34,16 +39,18 @@ public class Cons extends SExpression {
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return ("(" + toStringAux());
|
||||
return toStringTailRecursive("(").invoke();
|
||||
}
|
||||
|
||||
private String toStringAux() {
|
||||
if (rest.isNull())
|
||||
return (first.toString() + ")");
|
||||
else if (rest.isCons())
|
||||
return (first.toString() + " " + ((Cons) rest).toStringAux());
|
||||
private TailCall<String> toStringTailRecursive(String precedingString) {
|
||||
String leadingString = precedingString + first.toString();
|
||||
|
||||
return (first.toString() + " . " + rest.toString() + ")");
|
||||
if (rest.isNull())
|
||||
return done(leadingString + ")");
|
||||
else if (rest.isCons())
|
||||
return tailCall(() -> ((Cons) rest).toStringTailRecursive(leadingString + " "));
|
||||
|
||||
return done(leadingString + " . " + rest.toString() + ")");
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user