SNMOJ 31

 

考虑将给入的$A$数组差分,得到差分数组$C$

每一次操作相当于把差分数组的每一位${+1}$,其中一个位置上${-n+1}$。

我们可以直接算出要进行多少次操作:${T=\frac{\sum A[i]}{n*(n+1)/2}}$当然如果不能整除的话,说明一定无解。

问题转化为当前状态为$C$,目标状态为${E\left \{ T,T...,T \right \}}$每次要选择一个位置${+n}$,问是否可以刚好$T$步到达目标状态。

比如:

$${A\left \{ \left. 6,9,12,10,8 \right \} \right.}$$

$${C\left \{ \left. -2,3,3,-2,-2 \right \} \right.}$$

$${E\left \{ 3,3,3,3,3 \right \}}$$

显然在$1,4,5$号位置上各操作一次,一共操作$3$次即可,满足要求。


 

但是有一个小Trick:

3
5 1 6 
View Code

 

转载于:https://www.cnblogs.com/Dragon-Light/p/6416916.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值