Testing for Primality – Improved

Improved version of Testing for primality

(define (smallest-divisor n)
(find-divisor n 2))
(define (find-divisor n test-divisor)
(cond
((> (square test-divisor) n)
n)
((divides? test-divisor n)
test-divisor)
(else
(if
(= 2 test-divisor)
(find-divisor n (+ test-divisor 1))
(find-divisor n (+ test-divisor 2))))))
(define (divides? a b)
(= (remainder b a) 0))
(define (prime? n)
(= n (smallest-divisor n)))