結果

問題 No.406 鴨等間隔の法則
ユーザー tsuchinaga
提出日時 2019-02-21 12:28:06
言語 Go
(1.23.4)
結果
AC  
実行時間 935 ms / 2,000 ms
コード長 437 bytes
コンパイル時間 13,990 ms
コンパイル使用メモリ 225,348 KB
実行使用メモリ 7,836 KB
最終ジャッジ日時 2024-07-07 12:35:32
合計ジャッジ時間 30,610 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 29
権限があれば一括ダウンロードができます

ソースコード

diff #

package main

import (
	"fmt"
	"sort"
)

func main() {
	var n, x int
	_, _ = fmt.Scan(&n)

	nums := make([]int, n)
	for i := range nums {
		_, _ = fmt.Scan(&x)
		nums[i] = x
	}

	sort.Slice(nums, func(i, j int) bool {
		return nums[i] < nums[j]
	})

	diff := nums[1] - nums[0]
	for i := range nums {
		if i < 2 {
			continue
		}

		if diff == 0 || nums[i]-nums[i-1] != diff {
			fmt.Println("NO")
			return
		}
	}

	fmt.Println("YES")
}
0