CF296A.Yaroslav and Permutations

传统题 时间 2000 ms 内存 256 MiB 5 尝试 1 已通过 1 标签

Yaroslav and Permutations

Yaroslav has an array that consists of n integers. In one second Yaroslav can swap two neighboring array elements. Now Yaroslav is wondering if he can obtain an array where any two neighboring elements would be distinct in a finite time.

Help Yaroslav.

Input

The first line contains integer n (1 ≤ n ≤ 100) — the number of elements in the array. The second line contains n integers a1, a2, ..., a**n (1 ≤ a**i ≤ 1000) — the array elements.

Output

In the single line print "YES" (without the quotes) if Yaroslav can obtain the array he needs, and "NO" (without the quotes) otherwise.

Note

In the first sample the initial array fits well.

In the second sample Yaroslav can get array: 1, 2, 1. He can swap the last and the second last elements to obtain it.

In the third sample Yarosav can't get the array he needs.

Samples

1
1
YES
3
1 1 2
YES
4
7 7 7 7
NO

在线编程 IDE

建议全屏模式获得最佳体验