PolymathREU-Walking-to-infi.../scheme/append_digit_primes.scm
2020-07-13 09:06:43 -07:00

37 lines
1.2 KiB
Scheme

(load "util.scm")
(define (prime? n)
(if (< n 2) #f
(let loop ((i 2))
(cond
((> (* i i) n) #t)
((zero? (remainder n i)) #f)
(else (loop (+ i 1)))))))
(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))))))))
(define (next val)
(filter prime? (map (lambda (d) (+ (* val 10) d)) (range 10))))
; (define big-tree (tree 0 (filter prime? (range 1000000))))