题目大意
有一个数列 a 1 a_1 a1 ~ a n a_n an , 对其进行不少于 m m m 次操作,每次操作可以将任意一个数 a i ← a i + 1 a_i \gets a_i+1 ai←ai+1 ,求修改后的序列除去最大值和最小值后的和。
解题思路
首先可以想到,最小值 m m i n mmin mmin 对答案毫无贡献,所以 s u m sum sum 减去最小值 m m i n mmin mmin。
再按升序排序一遍,
然后可以想到三种情况:
- 可以将区间 [ a 2 , a n − 1 ] [a_2,a_{n-1}] [a2,an−1] 的部分数加到与最大值相等。
- 可以将区间 [ a 2 , a n − 1 ] [a_2,a_{n-1}] [a2,an−1] 的全部数加到与最大值相等,无法进行操作,即 m − x ≤ 1 m-x\leq1 m−x≤1( x x x 为之前操作的次数)。
- 将区间 [ a 2 , a n − 1 ] [a_2,a_{n-1}] [a2,an−1] 的全部数加到与最大值相等后,还可以做 m − x m-x m−x 次操作( x x x 为之前操作的次数, m − x > 1 m-x>1 m−x>1),则要把最大值 m m a x mmax mmax 提升,相当于提升上限,然后就可以再对区间 [ a 2 , a n − 1 ] [a_2,a_{n-1}] [a2,an−1] 的数进行操作。
AC CODE
#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,m,ans;
int sum;
int minn = INT_MAX;
int maxn = INT_MIN;
signed main()
{
cin >> n >> m;
sum = m;
for(int i = 1;i <= n;i++)
{
int x;
cin >> x;
minn = min(minn,x);
maxn = max(maxn,x);
sum += x;
}
n--;
sum -= minn;
int op = (sum % n == 0 ? sum / n:sum / n + 1);
cout << sum - max(maxn, op);
return 0;
}