Код Ревью
Сравни свои решения
#| BEGIN (Введите свое решение) |#
(define (carmichael-test n)
(= (expmod 2 n n) 2))
(define (expmod base exp m)
(cond ((= exp 0) 1)
((even? exp)
(remainder (square (expmod base (/ exp 2) m))
m))
(else
(remainder (* base (expmod base (- exp 1) m))
m))))
(define (square n)
(* n n))
#| END |#
#| BEGIN (Введите свое решение) |#
(define (carmichael-test n)
(define (try-it n a)
(cond ((= a 1) #t)
((not (= (expmod a n n) a)) #f)
(else (try-it n (- a 1)))))
(try-it n (- n 1)))
(define (expmod base exp m)
(cond ((= exp 0) 1)
((even? exp)
(remainder (square (expmod base (/ exp 2) m))
m))
(else
(remainder (* base (expmod base (- exp 1) m))
m))))
(define (square n)
(* n n))
#| END |#
#| BEGIN (Введите свое решение) |#
(define (carmichael-test n)
(= (expmod 2 n n) 2))
(define (expmod base exp m)
(cond ((= exp 0) 1)
((even? exp)
(remainder (square (expmod base (/ exp 2) m))
m))
(else
(remainder (* base (expmod base (- exp 1) m))
m))))
(define (square n)
(* n n))
#| END |#
#| BEGIN (Введите свое решение) |#
(define (carmichael-test n)
(define (try-it n a)
(cond ((= a 1) #t)
((not (= (expmod a n n) a)) #f)
(else (try-it n (- a 1)))))
(try-it n (- n 1)))
(define (expmod base exp m)
(cond ((= exp 0) 1)
((even? exp)
(remainder (square (expmod base (/ exp 2) m))
m))
(else
(remainder (* base (expmod base (- exp 1) m))
m))))
(define (square n)
(* n n))
#| END |#