(defun my-reduce (x y) (if (= 0 (mod x y)) (my-reduce (/ x y) y) x)) (defun max-factor-impl (x cur) (let ((next-x (my-reduce x cur))) (if (= 1 next-x) cur (max-factor-impl next-x (+ 1 cur))))) (defun max-factor (x) (max-factor-impl x 2)) (format t "~&~S~%" (max-factor 600851475143))