src/problems/pper.lisp @ e3aefcbf364c
Cache Uniprot results on the filesystem This will make only the first `(run-tests)` on a given computer take forever, instead of the first `(run-tests)` of a given Lisp session. It will also hopefully make the Uniprot folks not hate me.
| author | Steve Losh <steve@stevelosh.com> |
|---|---|
| date | Fri, 24 Jan 2020 23:05:16 -0500 |
| parents | 2735aa6aab79 |
| children | (none) |
(defpackage :rosalind/pper (:use :cl :rosalind :losh :iterate)) (in-package :rosalind/pper) (defparameter *input* "21 7") (defparameter *output* "51200") (define-problem pper (data stream) *input* *output* (let ((total (read data)) (size (read data))) ;; The number of combinations of k out of n elements is: ;; ;; (n choose k) = n! / k!(n-k)! ;; ;; To get the number of permutations, we multiply by the number of different ;; ways to order the k elements and it ends up simplifying nicely: ;; ;; k!(n choose k) = k!n! / k!(n-k)! ;; = n! / (n-k)! ;; = (n)(n-1)(n-2)…(n-(k-1)) ;; (flet ((count-permutations (size total) (iterate (for i :downfrom total) (repeat size) (multiplying i)))) (mod (count-permutations size total) 1000000))))