Browse Source

3 Largest Prime Factor

Mistivia 4 months ago
parent
commit
e685ad97fa
1 changed files with 16 additions and 0 deletions
  1. 16 0
      0003/main.lisp

+ 16 - 0
0003/main.lisp

@@ -0,0 +1,16 @@
+(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))
+