PolymathREU-Walking-to-infi.../scheme/tree.scm

32 lines
1.1 KiB
Scheme
Raw Normal View History

2020-07-13 09:06:43 -07:00
(load "util.scm")
(define (val tree) (car tree))
(define (children tree) (cdr tree))
(define (new-tree val children)
(let loop ((ls '()) (children children))
(if (null? children) (cons val ls)
(loop (append ls (new-tree (car children) '())) (cdr children)))))
(define (tree val children)
(new-tree val (map (lambda (x) (new-tree x '())) children)))
(define (tree-step tree)
(if (null? (children tree))
(new-tree (val tree) (map (lambda (x) (new-tree x '())) (next (val tree))))
(new-tree (val tree) (map tree-step (children tree)))))
(define (longest-path tree)
(cdr (let longest-path ((tree tree))
(if (null? (children tree))
(list (val tree))
(cons (val tree)
(fold (lambda (curr prev) (if (< (length prev) (length curr)) curr prev))
'()
(map longest-path (children tree))))))))
2020-07-17 22:03:58 -07:00
; --- change this function to control behavior of tree ---
2020-07-13 09:06:43 -07:00
(define (next val)
(filter prime? (map (lambda (d) (+ (* val 10) d)) (range 10))))
2020-07-17 22:03:58 -07:00
; (define (next val)
; (filter prime? (map (lambda (d) (+ (* d (expt 10 (digits val))) val)) (cdr (range 10)))))