結果

問題 No.156 キャンディー・ボックス
コンテスト
ユーザー Common Lisp
提出日時 2024-10-08 13:13:59
言語 Common Lisp
(sbcl 2.6.3)
コンパイル:
sbclc _filename_
実行:
sbcl --script Main.fasl
結果
WA  
実行時間 -
コード長 934 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 577 ms
コンパイル使用メモリ 29,696 KB
実行使用メモリ 22,528 KB
最終ジャッジ日時 2026-04-24 23:21:48
合計ジャッジ時間 2,555 ms
ジャッジサーバーID
(参考情報)
judge1_1 / judge4_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2 WA * 2
other AC * 12 WA * 18
権限があれば一括ダウンロードができます
コンパイルメッセージ
; compiling file "/home/judge/data/code/Main.lisp" (written 24 APR 2026 11:21:45 PM):

; wrote /home/judge/data/code/Main.fasl
; compilation finished in 0:00:00.020

ソースコード

diff #
raw source code

; 与えられた 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-not #'minusp (map 'list (lambda (x) (- x m)) (scanl1 #'+ xs)))))
    (terpri)))
(main)
0