結果
| 問題 | No.609 Noelちゃんと星々 |
| コンテスト | |
| ユーザー |
tsuchinaga
|
| 提出日時 | 2019-04-10 09:19:22 |
| 言語 | Go (1.26.1) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 992 bytes |
| 記録 | |
| コンパイル時間 | 13,609 ms |
| コンパイル使用メモリ | 282,364 KB |
| 実行使用メモリ | 7,720 KB |
| 最終ジャッジ日時 | 2026-03-28 00:56:32 |
| 合計ジャッジ時間 | 13,019 ms |
|
ジャッジサーバーID (参考情報) |
judge1_0 / judge3_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | WA * 25 |
ソースコード
package main
import (
"bufio"
"fmt"
"math"
"os"
"strconv"
)
func main() {
var n int
_, _ = fmt.Scan(&n)
sc := bufio.NewScanner(os.Stdin)
sc.Split(bufio.ScanWords)
nums := make([]int, n)
min := math.MaxInt64
max := math.MinInt64
for i := range nums {
sc.Scan()
a, _ := strconv.Atoi(sc.Text())
nums[i] = a
if min > a {
min = a
}
if max < a {
max = a
}
}
// fmt.Println(min, max)
// fmt.Println(nums)
var minD, maxD int
for _, a := range nums {
minD += int(math.Abs(float64(min - a)))
maxD += int(math.Abs(float64(max - a)))
}
// fmt.Println(minD, maxD)
for math.Abs(float64(max-min)) > 1 {
c := (max + min) / 2
d := 0
for _, a := range nums {
d += int(math.Abs(float64(c - a)))
}
if maxD > minD {
max = c
maxD = d
} else if maxD < minD {
min = c
minD = d
} else {
min, minD, max, maxD = c, d, c, d
}
fmt.Println(min, minD, max, maxD, c, d)
}
fmt.Println(int(math.Min(float64(minD), float64(maxD))))
}
tsuchinaga