結果
問題 |
No.126 2基のエレベータ
|
ユーザー |
![]() |
提出日時 | 2019-03-29 12:33:26 |
言語 | Go (1.23.4) |
結果 |
WA
|
実行時間 | - |
コード長 | 730 bytes |
コンパイル時間 | 14,509 ms |
コンパイル使用メモリ | 234,448 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-07 01:13:47 |
合計ジャッジ時間 | 12,625 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 21 WA * 6 |
ソースコード
package main import ( "fmt" "math" ) func main() { var a, b, s, ans int _, _ = fmt.Scan(&a, &b, &s) if s > 1 { // 2階以上にいるとき // 近いほうが迎えにくる if math.Abs(float64(a-s)) <= math.Abs(float64(b-s)) { ans += int(math.Abs(float64(a - s))) a = s } else { ans += int(math.Abs(float64(b - s))) b = s } // bに乗っている場合、Aのいる階に、行けなければ1階に行く if s == b { if a == 0 { ans += b - 1 b, s = 1, 1 } else { ans += int(math.Abs(float64(a - s))) b, s = a, a } } } // Aのエレベータに乗って目的地に行く if s != a { ans += int(math.Abs(float64(a - s))) a = s } ans += a fmt.Println(ans) }