結果
| 問題 |
No.609 Noelちゃんと星々
|
| コンテスト | |
| ユーザー |
tsuchinaga
|
| 提出日時 | 2019-04-10 09:19:22 |
| 言語 | Go (1.23.4) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 992 bytes |
| コンパイル時間 | 11,823 ms |
| コンパイル使用メモリ | 238,320 KB |
| 実行使用メモリ | 6,948 KB |
| 最終ジャッジ日時 | 2024-07-06 11:49:28 |
| 合計ジャッジ時間 | 11,498 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| 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