結果
問題 | No.156 キャンディー・ボックス |
ユーザー | Common Lisp |
提出日時 | 2024-10-08 13:14:38 |
言語 | Common Lisp (sbcl 2.3.8) |
結果 |
AC
|
実行時間 | 11 ms / 2,000 ms |
コード長 | 929 bytes |
コンパイル時間 | 346 ms |
コンパイル使用メモリ | 27,776 KB |
実行使用メモリ | 22,016 KB |
最終ジャッジ日時 | 2024-10-08 13:14:41 |
合計ジャッジ時間 | 2,083 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 9 ms
21,888 KB |
testcase_01 | AC | 9 ms
21,888 KB |
testcase_02 | AC | 9 ms
21,888 KB |
testcase_03 | AC | 9 ms
21,760 KB |
testcase_04 | AC | 9 ms
21,760 KB |
testcase_05 | AC | 9 ms
21,888 KB |
testcase_06 | AC | 9 ms
21,888 KB |
testcase_07 | AC | 9 ms
21,888 KB |
testcase_08 | AC | 9 ms
21,888 KB |
testcase_09 | AC | 10 ms
21,888 KB |
testcase_10 | AC | 11 ms
21,888 KB |
testcase_11 | AC | 10 ms
21,760 KB |
testcase_12 | AC | 10 ms
21,760 KB |
testcase_13 | AC | 11 ms
21,888 KB |
testcase_14 | AC | 10 ms
21,888 KB |
testcase_15 | AC | 9 ms
21,760 KB |
testcase_16 | AC | 11 ms
21,888 KB |
testcase_17 | AC | 11 ms
21,760 KB |
testcase_18 | AC | 11 ms
21,888 KB |
testcase_19 | AC | 11 ms
21,888 KB |
testcase_20 | AC | 10 ms
21,888 KB |
testcase_21 | AC | 10 ms
21,888 KB |
testcase_22 | AC | 10 ms
21,760 KB |
testcase_23 | AC | 10 ms
21,888 KB |
testcase_24 | AC | 11 ms
21,888 KB |
testcase_25 | AC | 10 ms
21,888 KB |
testcase_26 | AC | 10 ms
21,888 KB |
testcase_27 | AC | 11 ms
21,888 KB |
testcase_28 | AC | 10 ms
21,888 KB |
testcase_29 | AC | 10 ms
22,016 KB |
testcase_30 | AC | 11 ms
21,760 KB |
testcase_31 | AC | 11 ms
21,888 KB |
testcase_32 | AC | 10 ms
21,888 KB |
testcase_33 | AC | 10 ms
21,888 KB |
コンパイルメッセージ
; compiling file "/home/judge/data/code/Main.lisp" (written 08 OCT 2024 01:14:38 PM): ; wrote /home/judge/data/code/Main.fasl ; compilation finished in 0:00:00.008
ソースコード
; 与えられた Ci を昇順ソートして小さいものから足し続ける ; m を超えたときのインデックスを出力する ; 【解1】for ループ ; (defun main () ; (let* ((n (read)) ; (m (read)) ; (xs (sort (loop repeat n collect (read)) #'<))) ; (loop for i below n ; for s = (car xs) then (+ s (nth i xs)) ; until (> s m) ; finally (princ i)) ; (terpri))) ; (main) ; 【解2】再帰 (defun scanl1 (func lst) (if (null lst) (error "Empty list provided to scanl1") (let ((result (list (car lst)))) (dolist (item (cdr lst) (reverse result)) (push (funcall func (car result) item) result))))) (defun main () (let* ((n (read)) (m (read)) (xs (sort (loop repeat n collect (read)) #'<))) (princ (length (remove-if #'plusp (map 'list (lambda (x) (- x m)) (scanl1 #'+ xs))))) (terpri))) (main)