結果

問題 No.792 真理関数をつくろう
ユーザー iwotiwot
提出日時 2020-09-12 14:37:50
言語 Common Lisp
(sbcl 2.5.0)
結果
AC  
実行時間 31 ms / 2,000 ms
コード長 1,423 bytes
コンパイル時間 1,170 ms
コンパイル使用メモリ 38,056 KB
実行使用メモリ 34,944 KB
最終ジャッジ日時 2025-01-01 23:42:05
合計ジャッジ時間 2,560 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 7 ms
22,120 KB
testcase_01 AC 11 ms
26,664 KB
testcase_02 AC 7 ms
22,124 KB
testcase_03 AC 12 ms
28,692 KB
testcase_04 AC 8 ms
25,892 KB
testcase_05 AC 11 ms
24,640 KB
testcase_06 AC 21 ms
28,808 KB
testcase_07 AC 8 ms
22,376 KB
testcase_08 AC 7 ms
22,120 KB
testcase_09 AC 8 ms
24,164 KB
testcase_10 AC 7 ms
24,168 KB
testcase_11 AC 8 ms
21,996 KB
testcase_12 AC 7 ms
22,120 KB
testcase_13 AC 7 ms
22,116 KB
testcase_14 AC 8 ms
22,124 KB
testcase_15 AC 7 ms
24,296 KB
testcase_16 AC 13 ms
26,692 KB
testcase_17 AC 8 ms
26,276 KB
testcase_18 AC 8 ms
22,120 KB
testcase_19 AC 7 ms
22,120 KB
testcase_20 AC 10 ms
24,600 KB
testcase_21 AC 31 ms
34,944 KB
testcase_22 AC 8 ms
22,376 KB
testcase_23 AC 7 ms
21,868 KB
testcase_24 AC 7 ms
22,124 KB
testcase_25 AC 7 ms
24,264 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
; compiling file "/home/judge/data/code/Main.lisp" (written 01 JAN 2025 11:42:01 PM):

; file: /home/judge/data/code/Main.lisp
; in: DEFUN SOLVE-LINES
;     (DEFUN SOLVE-LINES (N LIMIT)
;       (LET ((RESULT (MAKE-ARRAY LIMIT :INITIAL-ELEMENT NIL)))
;         (DOTIMES (IDX LIMIT) (SETF # #))
;         RESULT))
; --> SB-IMPL::%DEFUN SB-IMPL::%DEFUN SB-INT:NAMED-LAMBDA 
; ==>
;   #'(SB-INT:NAMED-LAMBDA SOLVE-LINES
;         (N LIMIT)
;       (DECLARE (SB-C::TOP-LEVEL-FORM))
;       (BLOCK SOLVE-LINES
;         (LET ((RESULT #))
;           (DOTIMES (IDX LIMIT) (SETF #))
;           RESULT)))
; 
; caught STYLE-WARNING:
;   The variable N is defined but never used.
; 
; compilation unit finished
;   caught 1 STYLE-WARNING condition


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

ソースコード

diff #

(defun split-to-apply-fun-by-space (str num f &optional (result ()))
    (if (< num (length str))
        (if (char= (char str num) #\Space)
            (split-to-apply-fun-by-space str (+ 1 num) f result)
            (split-to-apply-fun-by-space str (+ 1 num) f (cons (funcall f (+ 1 (length result)) (char str num)) result)))
        (reverse result)))

(defun char-bool-to-p-str (num c)
    (if (char= #\0 c) (format nil "¬P_~A" num) (format nil "P_~A" num)))

(defun solve-line (s)
    (if (char= #\0 (aref s (- (length s) 1)))
        nil
        (split-to-apply-fun-by-space (subseq s 0 (- (length s) 1)) 0 #'char-bool-to-p-str)))

(defun join-by-AND (ss)
    (if (null ss) ss
        (format nil "(~{~A~^∧~})" ss)))

(defun solve-lines (n limit)
    (let ((result (make-array limit :initial-element nil)))
        (dotimes (idx limit)
            (setf (aref result idx) (join-by-AND (solve-line (read-line)))))
        result))

(defun output-lines (ss)
    (loop for i from 0
          until (>= i (length ss))
          do (if (> i 0) (format t "∨"))
             (format t (aref ss i))))

(let* ((n (parse-integer (read-line)))
       (m (solve-lines n (expt 2 n)))
       (m2 (remove-if (lambda (x) (null x)) m)))
    (format t "A=")
    (if (= 0 (length m2))
        (format t "⊥")
        (if (= (length m2) (expt 2 n))
            (format t "⊤")
            (output-lines m2)))
    (format t "~%"))
0