2015-01-17 23:20:54 -05:00
|
|
|
;;; TAKL -- The TAKeuchi function using lists as counters.
|
|
|
|
|
2015-01-17 23:30:54 -05:00
|
|
|
(import (scheme base)
|
|
|
|
(scheme read)
|
|
|
|
(scheme write))
|
2015-01-17 23:20:54 -05:00
|
|
|
|
|
|
|
(define (listn n)
|
|
|
|
(if (= n 0)
|
|
|
|
'()
|
|
|
|
(cons n (listn (- n 1)))))
|
|
|
|
|
|
|
|
(define l18 (listn 18))
|
|
|
|
(define l12 (listn 12))
|
|
|
|
(define l6 (listn 6))
|
|
|
|
|
|
|
|
(define (mas x y z)
|
|
|
|
(if (not (shorterp y x))
|
|
|
|
z
|
|
|
|
(mas (mas (cdr x) y z)
|
|
|
|
(mas (cdr y) z x)
|
|
|
|
(mas (cdr z) x y))))
|
|
|
|
|
|
|
|
(define (shorterp x y)
|
|
|
|
(and (not (null? y))
|
|
|
|
(or (null? x)
|
|
|
|
(shorterp (cdr x)
|
|
|
|
(cdr y)))))
|
|
|
|
|
|
|
|
(define (main)
|
|
|
|
(let* ((count (read))
|
|
|
|
(input1 (read))
|
|
|
|
(input2 (read))
|
|
|
|
(input3 (read))
|
|
|
|
(output (read))
|
|
|
|
(s4 (number->string count))
|
|
|
|
(s3 (number->string (length input3)))
|
|
|
|
(s2 (number->string (length input2)))
|
|
|
|
(s1 (number->string (length input1)))
|
|
|
|
(name "takl"))
|
2015-01-17 23:30:54 -05:00
|
|
|
(run-r7rs-benchmark
|
2015-01-17 23:20:54 -05:00
|
|
|
(string-append name ":" s1 ":" s2 ":" s3 ":" s4)
|
|
|
|
count
|
|
|
|
(lambda ()
|
|
|
|
(mas (hide count input1) (hide count input2) (hide count input3)))
|
|
|
|
(lambda (result) (equal? (length result) output)))))
|
2015-01-17 23:30:54 -05:00
|
|
|
|
|
|
|
(include "src/common.sch")
|