結果

問題 No.126 2基のエレベータ
ユーザー tsuchinaga
提出日時 2019-03-29 12:38:14
言語 Go
(1.23.4)
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 1,055 bytes
コンパイル時間 10,725 ms
コンパイル使用メモリ 226,868 KB
実行使用メモリ 6,820 KB
最終ジャッジ日時 2024-10-10 18:33:57
合計ジャッジ時間 11,546 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 27
権限があれば一括ダウンロードができます

ソースコード

diff #

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階にいってAを呼んで地下に行くのと早い方を選択する
		// bに乗っている場合、Aのいる階に、行けなければ1階に行く
		if s == b {
			if a == 0 {
				ans += b - 1
				b, s = 1, 1
			} else {
				if math.Abs(float64(a-s)) < math.Abs(float64(s-1)) { // Aに行く方が近い
					ans += int(math.Abs(float64(a - s)))
					b, s = a, a
				} else { // 1階に行く方が近い
					ans += s - 1
					b, s = 1, 1
				}
			}
		}
	}

	// Aのエレベータに乗って目的地に行く
	if s != a {
		ans += int(math.Abs(float64(a - s)))
		a = s
	}
	ans += a

	fmt.Println(ans)
}
0