ラケット-126バイトから98バイトまで 91バイト
非常に素朴な解決策-まともなアルゴリズムと私が知らないいくつかのLispトリックでおそらく大幅に削減できます
(define(g x[c 0][d 0][i 2])(cond[(= x 0)c][(= i x)(g d(+ 1 c))][(=(modulo x i)0)(g x c d(+ 1 i))][else(g x c(+ 1 d)(+ 1 i))]))
編集:リクエストによる説明。私が言ったように、これは非常に単純な再帰的な解決策であり、はるかに短くすることができます。
(define (g x [c 0] [d 0] [i 2]) ;g is the name of the function - arguments are x (input), c (counter for steps), d (non-divisor counter), i (iterator)
(cond
[(= x 0) c] ;once x gets to 0 c is outputted
[(= i x) (g d (+ 1 c))] ;if iterator reaches x then we recurse with d as input and add 1 to c
[(= (modulo x i) 0) (g x c d (+ 1 i))] ;checks if iterator is non divisor, then adds it to d and increments iterator
[else(g x c (+ 1 d) (+ 1 i))])) ;otherwise just increments iterator
編集2:より愚かなアルゴリズムの98バイトバージョン(まだかなり愚かであり、より短くすることができます)
(define(g x)(if(< x 1)0(+ 1(g(length(filter(λ(y)(>(modulo x y)0))(cdr(build-list x values))))))))
説明:
(define (g x) ;function name g, input x
(if (< x 1)
0 ;returns 0 if x < 1 (base case)
(+ 1 ;simple recursion - adds 1 to output for each time we're looping
(g (length ;the input we're passing is the length of...
(filter (λ (y) (> (modulo x y) 0)) ;the list where all numbers which are 0 modulo x are 0 are filtered out from...
(cdr (build-list x values)))))))) ;the list of all integers up to x, not including 0
編集3:と交換(cdr(build-list x values))
して7バイトを保存(build-list x add1)
(define(g x)(if(< x 1)0(+ 1(g(length(filter(λ(y)(>(modulo x y)0))(build-list x add1)))))))