CF1513E.Cost Equilibrium
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
An array is called beautiful if all the elements in the array are equal.
You can transform an array using the following steps any number of times:
- Choose two indices i and j ( 1≤i,j≤n ), and an integer x ( 1≤x≤ai ). Let i be the source index and j be the sink index.
- Decrease the i -th element by x , and increase the j -th element by x . The resulting values at i -th and j -th index are ai−x and aj+x respectively.
- The cost of this operation is $x \cdot |j-i| $ .
- Now the i -th index can no longer be the sink and the j -th index can no longer be the source.
The total cost of a transformation is the sum of all the costs in step 3 .For example, array [0,2,3,3] can be transformed into a beautiful array [2,2,2,2] with total cost 1⋅∣1−3∣+1⋅∣1−4∣=5 .
An array is called balanced, if it can be transformed into a beautiful array, and the cost of such transformation is uniquely defined. In other words, the minimum cost of transformation into a beautiful array equals the maximum cost.
You are given an array a1,a2,…,an of length n , consisting of non-negative integers. Your task is to find the number of balanced arrays which are permutations of the given array. Two arrays are considered different, if elements at some position differ. Since the answer can be large, output it modulo 109+7 .
输入格式
The first line contains a single integer n ( 1≤n≤105 ) — the size of the array.
The second line contains n integers a1,a2,…,an ( 0≤ai≤109 ).
输出格式
Output a single integer — the number of balanced permutations modulo 109+7 .
输入输出样例
输入#1
3 1 2 3
输出#1
6
输入#2
4 0 4 0 4
输出#2
2
输入#3
5 0 11 12 13 14
输出#3
120
说明/提示
In the first example, [1,2,3] is a valid permutation as we can consider the index with value 3 as the source and index with value 1 as the sink. Thus, after conversion we get a beautiful array [2,2,2] , and the total cost would be 2 . We can show that this is the only transformation of this array that leads to a beautiful array. Similarly, we can check for other permutations too.
In the second example, [0,0,4,4] and [4,4,0,0] are balanced permutations.
In the third example, all permutations are balanced.