結果

問題 No.126 2基のエレベータ
ユーザー TANIGUCHI Kousuke
提出日時 2019-10-31 12:25:24
言語 Ruby
(3.4.1)
結果
AC  
実行時間 89 ms / 5,000 ms
コード長 502 bytes
コンパイル時間 240 ms
コンパイル使用メモリ 7,552 KB
実行使用メモリ 12,288 KB
最終ジャッジ日時 2024-10-10 18:34:43
合計ジャッジ時間 3,864 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 27
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

A,B,S = gets.split.map(&:to_i)
if S == 1 || (A - S).abs <= (B - S).abs
  # Aが優先される場合
  puts (A - S).abs + S  
elsif A <= 1
  # Bが優先されるけど、1階で確実にAに乗り換える場合
  puts (B - S).abs + (S - 1) + (A - 1).abs + 1
else
  # Bで移動後、Aに乗る場合
  # 1. Bで1階に移動して、下を押す
  # 2. Aとおなじ階まで移動して、下を押す
  puts [ (B - S).abs + (S - 1) + (A - 1).abs + 1,
        (B - S).abs + (S - A).abs + A].min
end
0