結果
問題 | No.48 ロボットの操縦 |
ユーザー |
|
提出日時 | 2018-03-10 19:57:36 |
言語 | Go (1.23.4) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,270 bytes |
コンパイル時間 | 12,026 ms |
コンパイル使用メモリ | 239,580 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-10-14 17:53:56 |
合計ジャッジ時間 | 13,151 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 25 |
ソースコード
package mainimport ("bufio""fmt""math""os""strconv")// エントリポイントfunc main() {in := bufio.NewScanner(os.Stdin)// 移動先の東西軸座標in.Scan()input1 := in.Text()// 移動先の南北軸座標in.Scan()input2 := in.Text()// ロボットが1命令につき前進することができる最大の距離in.Scan()input3 := in.Text()fmt.Println(maneuver(input1, input2, input3))}// 何回命令すれば目的地に到着できるか計算する。func maneuver(eastWest string, northSouth string, distance string) string {e, _ := strconv.Atoi(eastWest)n, _ := strconv.Atoi(northSouth)d, _ := strconv.Atoi(distance)orderCount := 0eFloat := float64(e)nFloat := float64(n)dFloat := float64(d)// 先に進行の命令数を計算progressNS := int(math.Ceil(math.Abs(nFloat / dFloat)))progressEW := int(math.Ceil(math.Abs(eFloat / dFloat)))if n == 0 && e != 0 {// 東西のみorderCount++orderCount += progressEW} else if n < 0 {// 先に東西に向かうorderCount++orderCount += progressEWorderCount++orderCount += progressNS} else {orderCount += progressNSif e != 0 {orderCount++orderCount += progressEW}}return strconv.Itoa(orderCount)}