結果

問題 No.48 ロボットの操縦
コンテスト
ユーザー Common Lisp
提出日時 2024-10-07 12:22:40
言語 Common Lisp
(sbcl 2.6.3)
コンパイル:
sbclc _filename_
実行:
sbcl --script Main.fasl
結果
AC  
実行時間 11 ms / 5,000 ms
コード長 601 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 593 ms
コンパイル使用メモリ 31,888 KB
実行使用メモリ 30,108 KB
最終ジャッジ日時 2026-04-24 03:18:52
合計ジャッジ時間 1,954 ms
ジャッジサーバーID
(参考情報)
judge1_0 / judge2_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 25
権限があれば一括ダウンロードができます
コンパイルメッセージ
; compiling file "/home/judge/data/code/Main.lisp" (written 24 APR 2026 03:18:47 AM):

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

ソースコード

diff #
raw source code

; 目的地に到達するためには多くて方向転換が2回
; k = ⌈|x| / l⌉ + ⌈|y| / l⌉ として
; x = 0 かつ y >= 0 のとき k
; x /= 0 かつ y >= 0 のとき k + 1
; その他の場合 k + 2
(defun main ()
  (let* ((x (read))
         (y (read))
         (l (read))     ; abs 関数は絶対値
         (k (+ (ceiling (abs x) l) (ceiling (abs y) l)))
         (ans (cond
               ((and (= x 0) (>= y 0)) k)
                     ; (/= x y) は (not (= x y))
               ((and (/= x 0) (>= y 0)) (1+ k))
               (t (+ k 2)))))
    (princ ans)
    (terpri)))
(main)
0