P1031均分纸牌

博客介绍了P1031均分纸牌问题,给出了具体的移动规则和示例。通过求解每堆纸牌与平均数的差值,确定最少移动次数实现所有堆纸牌数量相等。文章提供了AC代码示例,并展示了多个测试用例及它们的解题过程。
摘要由CSDN通过智能技术生成

原题链接:P1031
题目描述
有N堆纸牌,编号分别为 1,2,…,N。每堆上有若干张,但纸牌总数必为N的倍数。可以在任一堆上取若干张纸牌,然后移动。
移牌规则为:在编号为1堆上取的纸牌,只能移到编号为2的堆上;在编号为N的堆上取的纸牌,只能移到编号为N-1的堆上;其他堆上取的纸牌,可以移到相邻左边或右边的堆上。
现在要求找出一种移动方法,用最少的移动次数使每堆上纸牌数都一样多。
例如N=4,4堆纸牌数分别为:
①9②8③17④6
移动3次可达到目的:
从 ③ 取4张牌放到 ④ (9,8,13,10)-> 从 ③ 取33张牌放到 ②(9,11,10,10)-> 从 ② 取11张牌放到①(10,10,10,10)。
输入格式
两行
第一行为:N(N 堆纸牌,1≤N≤100)
第二行为:A_1,A_2, … ,A_n (N堆纸牌,每堆纸牌初始数,1≤A≤10000)
输出格式
一行:即所有堆均达到相等时的最少移动次数。
输入输出样例
输入 #1复制
4
9 8 17 6
输出 #1复制
3
解题思路:
题目大意:有N堆牌,总数为N的整数倍,求最少移动次数使每堆牌的数量相等。移动方式:第1堆牌只能移动第2堆牌,第N堆牌只能移动到第N-1堆牌。其他堆的牌,可以移动到相邻左堆或右堆。
思路:首先求出每堆牌与平均数的差值,然后一堆一堆牌来处理,如果处理的这堆牌的差值为0,就不用移动了,它已经达到条件了。否则就将这堆牌的差值转接到下一堆牌差值上,移动次数加1,这堆牌就处理完毕了,不用管了。(按这个方法,如果这堆牌的差值为0的话,就是说前面的几堆牌可以内部分配成各自相等的情况。)

AC代码:


                
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值