; counting ones
(define (filter pred? xs)
(let loop ((xs xs) (ys '()))
(cond ((null? xs) (reverse ys))
((pred? (car xs))
(loop (cdr xs) (cons (car xs) ys)))
(else (loop (cdr xs) ys)))))
(define (digits n . args)
(let ((b (if (null? args) 10 (car args))))
(let loop ((n n) (d '()))
(if (zero? n) d
(loop (quotient n b)
(cons (modulo n b) d))))))
(define (one? x) (= 1 x))
(let loop ((n 0) (sum 0))
(when (= n sum) (display sum) (newline))
(loop (+ n 1) (+ sum (length (filter one? (digits (+ n 1)))))))