結果
問題 | No.5007 Steiner Space Travel |
ユーザー | motoshira |
提出日時 | 2023-04-23 21:23:00 |
言語 | Common Lisp (sbcl 2.5.0) |
結果 |
AC
|
実行時間 | 12 ms / 1,000 ms |
コード長 | 5,205 bytes |
コンパイル時間 | 828 ms |
コンパイル使用メモリ | 34,524 KB |
実行使用メモリ | 27,704 KB |
スコア | 1,221,702 |
最終ジャッジ日時 | 2023-04-23 21:23:04 |
合計ジャッジ時間 | 3,108 ms |
ジャッジサーバーID (参考情報) |
judge13 / judge11 |
純コード判定しない問題か言語 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 10 ms
25,648 KB |
testcase_01 | AC | 10 ms
23,588 KB |
testcase_02 | AC | 11 ms
27,664 KB |
testcase_03 | AC | 10 ms
27,704 KB |
testcase_04 | AC | 9 ms
23,636 KB |
testcase_05 | AC | 10 ms
23,616 KB |
testcase_06 | AC | 10 ms
23,624 KB |
testcase_07 | AC | 10 ms
23,612 KB |
testcase_08 | AC | 11 ms
27,636 KB |
testcase_09 | AC | 11 ms
25,892 KB |
testcase_10 | AC | 11 ms
25,732 KB |
testcase_11 | AC | 10 ms
25,676 KB |
testcase_12 | AC | 10 ms
25,688 KB |
testcase_13 | AC | 10 ms
23,568 KB |
testcase_14 | AC | 10 ms
23,668 KB |
testcase_15 | AC | 9 ms
23,612 KB |
testcase_16 | AC | 10 ms
23,588 KB |
testcase_17 | AC | 11 ms
25,672 KB |
testcase_18 | AC | 11 ms
25,700 KB |
testcase_19 | AC | 10 ms
23,604 KB |
testcase_20 | AC | 12 ms
25,792 KB |
testcase_21 | AC | 10 ms
25,608 KB |
testcase_22 | AC | 11 ms
27,600 KB |
testcase_23 | AC | 10 ms
23,636 KB |
testcase_24 | AC | 10 ms
25,672 KB |
testcase_25 | AC | 10 ms
23,592 KB |
testcase_26 | AC | 10 ms
23,700 KB |
testcase_27 | AC | 11 ms
25,624 KB |
testcase_28 | AC | 10 ms
23,608 KB |
testcase_29 | AC | 11 ms
25,628 KB |
コンパイルメッセージ
; compiling file "/home/judge/data/code/Main.lisp" (written 23 APR 2023 09:23:00 PM): ; processing (IN-PACKAGE #:CL-USER) ; processing (DECLAIM (OPTIMIZE # ...)) ; processing (DECLAIM (MUFFLE-CONDITIONS COMPILER-NOTE)) ; processing (DISABLE-DEBUGGER) ; processing (SET-DISPATCH-MACRO-CHARACTER #\# ...) ; processing (SET-DISPATCH-MACRO-CHARACTER #\# ...) ; processing (IN-PACKAGE #:CL-USER) ; processing (DEFMACRO AWHEN ...) ; processing (DEFMACRO WHILE ...) ; processing (DEFMACRO EVAL-ALWAYS ...) ; processing (IN-PACKAGE #:CL-USER) ; processing (DEFMACRO %EXPANDER-BODY ...) ; processing (DEFMACRO DEFINE-ECASE-EXPANDER ...) ; processing (EVAL-ALWAYS (DEFCONSTANT +PLANET-AMOUNT+ ...) ...) ; processing (DEFTYPE COORD ...) ; processing (DECLAIM (INLINE Y ...)) ; processing (DEFUN MAKE-COORD ...) ; processing (DEFUN Y ...) ; processing (DEFUN X ...) ; processing (DEFSTRUCT (INPUT #) ...) ; processing (DEFUN READ-INPUT ...) ; processing (DEFTYPE STATIONS ...) ; processing (DEFTYPE ORDERS ...) ; processing (DEFUN MAKE-STATION-COORDS ...) ; processing (DEFUN MAKE-ORDERS ...) ; processing (DEFUN PRINT-ANS ...) ; processing (DEFUN MAIN ...) ; processing (MAIN) ; wrote /home/judge/data/code/Main.fasl ; compilation finished in 0:00:00.081
ソースコード
(in-package #:cl-user) ;;; ;;; Init ;;; (eval-when (:compile-toplevel :load-toplevel :execute) ;; #+swank (declaim (optimize (speed 3) (safety 2))) #+swank (declaim (optimize (speed 0) (safety 3) (debug 3))) #-swank (declaim (optimize (speed 3) (safety 0) (debug 0))) #-swank (declaim (sb-ext:muffle-conditions sb-ext:compiler-note)) #-swank (sb-ext:disable-debugger)) ;;; ;;; Reader Macros ;;; (eval-when (:compile-toplevel :load-toplevel :execute) (set-dispatch-macro-character #\# #\f #'(lambda (stream c2 n) (declare (ignore c2 n)) (let ((form (read stream t nil t))) `(lambda (&optional %) (declare (ignorable %)) ,form)))) (set-dispatch-macro-character #\# #\> #'(lambda (stream c2 n) (declare (ignore c2 n)) (let ((form (read stream t nil t))) (declare (ignorable form)) #-swank nil #+swank (if (atom form) `(format *error-output* "~a => ~a~&" ',form ,form) `(format *error-output* "~a => ~a~&" ',form `(,,@form))))))) ;;; ;;; Libraries ;;; ;;; ;;; Macros ;;; (in-package #:cl-user) (defmacro awhen (test &body forms) `(let ((it ,test)) (when it ,@forms))) (defmacro while (test &body body) `(loop while ,test do (progn ,@body))) (defmacro eval-always (&body body) `(eval-when (:compile-toplevel :load-toplevel :execute) ,@body)) ;;; ;;; Body ;;; (in-package #:cl-user) (defmacro %expander-body (form cases) `(ecase ,form ,@(loop for (from . to) in cases collect `(,from ,to)))) (defmacro define-ecase-expander (name assoc-list) `(defmacro ,name (form) `(%expander-body ,form ,',assoc-list))) (eval-always (defconstant +planet-amount+ 100) (defconstant +station-amount+ 8) (defconstant +alpha+ 5)) (deftype coord () '(unsigned-byte 32)) (declaim (inline y x)) (defun make-coord (y x) #+swank (assert (<= 0 y 1000) () "y is out of range") #+swank (assert (<= 0 x 1000) () "x is out of range") (dpb y '#.(byte 16 16) x)) (defun y (c) (ldb (byte 16 16) c)) (defun x (c) (ldb (byte 16 0) c)) #+nil (y (make-coord 1000 0)) #+nil (x (make-coord 0 1000)) (defstruct (input (:conc-name in-)) (planets nil :type (simple-array coord (*)))) (defun read-input () (let ((n (read)) (m (read)) (planets (make-array +planet-amount+ :element-type 'coord))) (declare (ignore n m)) (dotimes (i +planet-amount+) (setf (aref planets i) (make-coord (read) (read)))) (make-input :planets planets))) (deftype stations () '(simple-array coord (*))) (deftype orders () "planetsはid0〜99, stationsはid100〜107 最初と最後はid0でないといけない" '(simple-array fixnum (*))) (defun make-station-coords (input) ;; TODO いい感じの場所に置く (declare (ignore input)) (let ((res (make-array +station-amount+ :element-type 'coord))) (dotimes (i +station-amount+) (setf (aref res i) (make-coord (random 1001) (random 1001)))) res)) (defun make-orders (input stations) ;; TODO ステーションを使う ;; TODO 各頂点間の距離を求めてTSPを解く (declare (ignore input stations)) (let* ((res (make-array (1+ +planet-amount+) :element-type 'fixnum))) (declare (orders res)) (loop for i below +planet-amount+ do (setf (aref res i) i)) (setf (aref res +planet-amount+) 0) res)) (defun print-ans (stations orders) (declare (orders orders) (stations stations)) ;; stations (sb-int:dovector (c stations) (format t "~a ~a~%" (y c) (x c))) (format t "~a ~%" (length orders)) ;; orders (sb-int:dovector (o orders) (multiple-value-bind (type id) (if (< o +planet-amount+) (values 1 o) (values 2 (- o +planet-amount+))) (format t "~a ~a~%" type (1+ id))))) (defun main () (let* ((input (read-input)) (stations (make-station-coords input)) (orders (make-orders input stations))) (print-ans stations orders))) #-swank (main) ;;; ;;; Debug ;;; ;; Raise error on warning at compile time #+(and sbcl (not swank)) (eval-when (:compile-toplevel) (when (or (plusp sb-c::*compiler-warning-count*) sb-c::*undefined-warnings*) (error "compiler-error-count:~a, undefined warnings:~a" sb-c::*compiler-warning-count* sb-c::*undefined-warnings*))) #+swank (defun run-sample (infile outfile &optional (out *standard-output*) (vis t)) (let ((args (append (list "tester.dll" "judge" "-i" infile "-o" outfile) (when vis (list "-v" "vis.png"))))) (with-open-file (*standard-input* infile :direction :input) (with-open-file (*standard-output* outfile :direction :output :if-exists :supersede) (main)) (sb-ext:run-program "dotnet" args :output out :search t :error *error-output*)))) #+swank (defun (infile outfile) (sb-ext:run-program "dotnet" (list "vis.dll" "judge" "-i" infile "-o" outfile) :output out :search t :error *error-output*))