P7713 「EZEC-10」打分

题目大意

有一个数列 a 1 a_1 a1 ~ a n a_n an , 对其进行不少于 m m m 次操作,每次操作可以将任意一个数 a i ← a i + 1 a_i \gets a_i+1 aiai+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,an1]部分数加到与最大值相等。
  • 可以将区间 [ a 2 , a n − 1 ] [a_2,a_{n-1}] [a2,an1]全部数加到与最大值相等,无法进行操作,即 m − x ≤ 1 m-x\leq1 mx1 x x x 为之前操作的次数)。
  • 将区间 [ a 2 , a n − 1 ] [a_2,a_{n-1}] [a2,an1]全部数加到与最大值相等后,还可以做 m − x m-x mx 次操作( x x x 为之前操作的次数, m − x > 1 m-x>1 mx>1),则要把最大值 m m a x mmax mmax 提升,相当于提升上限,然后就可以再对区间 [ a 2 , a n − 1 ] [a_2,a_{n-1}] [a2,an1] 的数进行操作。

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;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值