二分贪心——U
来源:互联网 发布:java小游戏超级玛丽 编辑:程序博客网 时间:2024/06/06 12:25
题目要求:
小鲍勃喜欢和他的砖块一起玩。他将砖块放在另一块上,并建立不同高度的堆垛。“看,我已经建了一堵墙!”他告诉他的姐姐爱丽丝。“呵呵,你应该把所有的堆叠都一样高,然后你会有一个真正的墙壁。”她反驳道。经过一番考虑后,鲍勃看到她是对的。所以他开始重新排列砖块,一个接一个,所有的堆叠都是相同的高度。但是,由于鲍勃懒惰,他想用最少数量的砖块来做到这一点。你能帮我吗?
题目思路:
要找最少移动数,就只要把大于平均数的数,给小于平均数的数匀几个。所以只要求出大于平均数的数减去平均数的和就能求出最小移动数。
细节处理
几个量的初值应该在while内赋值,防止错误答案。
几个量的初值应该在while内赋值,防止错误答案。
#include<iostream>using namespace std;int main(){ int n,i,j,N=0; int k[100]={0}; while(cin>>n) { if(n==0)break;int sum=0,s=0,a[50]; for(i=0;i<n;i++) {cin>>a[i]; s=s+a[i];} sum=s/n; for(i=0;i<n;i++) {if(a[i]>sum) k[N]+=a[i]-sum;} N++;} for(i=0;i<N;i++) { cout<<"Set #"<<i+1<<endl; cout<<"The minimum number of moves is "<<k[i]<<"."<<endl; cout<<endl;} return 0;}感悟:注意赋值位置的问题,注意细节处理。
0 0
- 二分贪心—U
- 二分贪心——U
- 二分贪心 U
- 二分贪心 U
- 二分贪心 U题
- 二分贪心-U
- 二分贪心—B
- 二分贪心—D
- 二分贪心—E
- 二分贪心—T
- 二分贪心—V
- 二分贪心—X
- 二分贪心 U 堆墙
- ACM-二分贪心U-21
- 二分贪心——B
- 二分贪心——E
- 2016春季练习——二分+贪心
- 二分+贪心——HDU 5855
- mysql内连接和外连接
- map 按key排序
- Python标准输出
- 完全教程 Aircrack-ng
- mysql允许某个ip访问
- 二分贪心——U
- 最小生成树Prim算法模板
- tp5安装workerman
- RxSwift(3.4.1)- Subjects
- java积累---------java判断两个set里的对象值完全相同----两个set中的值是否相等
- spring面试题
- springMVC中post提交中文乱码过滤器配置
- 在 win10 环境下,设置自己写的 程序 开机自动 启动的方法
- opencv-鼠标在窗口中画矩形