poj 1017 装箱子(模拟+贪心)
Description
A factory produces products packed in square packets of the same height h and of the sizes 1*1, 2*2, 3*3, 4*4, 5*5, 6*6. These products are always delivered to customers in the square parcels of the same height h as the products have and of the size 6*6. Because of the expenses it is the interest of the factory as well as of the customer to minimize the number of parcels necessary to deliver the ordered products from the factory to the customer. A good program solving the problem of finding the minimal number of parcels necessary to deliver the given products according to an order would save a lot of money. You are asked to make such a program.
Input
The input file consists of several lines specifying orders. Each line specifies one order. Orders are described by six integers separated by one representing successively the number of packets of individual size from the smallest size 1*1 to the biggest size 6*6. The end of the input file is indicated by the line containing six zeros.
Output
The output file contains one line for each line in the input file. This line contains the minimal number of parcels into which the order from the corresponding line of the input file can be packed. There is no line in the output file corresponding to the last ``null'' line of the input file.
Sample Input
0 0 4 0 0 1
7 5 1 0 0 0
0 0 0 0 0 0
Sample Output
2
1
解题思路:贪心法的思想,同时要仔细画图,分析箱子摆放的细节,从而得出解题的思路。
首先,对于边长为4,5,6的产品,那么只要有一个这样的产品,就必须要给一个边长为6的集装箱。对于边长为4,5的产品还要考虑在剩余的空间中放入尽可能多的2,1产品以节省空间。具体地讲,就是对于产品6,一个装一箱恰好装满;对于产品5,最多只能在剩余空间中装6*6-5*5=11个产品1了。对于产品4而言,装了一个产品4后,剩余空间中最多可以装5个产品2(可画图验证),剩余再考虑装入产品1。思路就是这样的一个由大到小的贪心的过程。
其次,对于产品3,2,1分别考虑:
对于边长为3的产品,四个一箱后会剩余1,2,3这3种可能的余数,分别考虑填放入边长为2,1的产品;
对于边长为2的产品,九个一箱后,剩余多少空格就直接用1产品填充就行。
对最后剩下的边长为1的产品,36个一箱的方案来装就可以了
程序源代码如下:
#include<iostream>
using namespace std;
int max(int a, int b){
if(a>b) return a;
else return b;
}
int main(){
int s1, s2, s3, s4, s5, s6;
while(cin>>s1>>s2>>s3>>s4>>s5>>s6)
{
if(s1==0&&s2==0&&s3==0&&s4==0&&s5==0&&s6==0)break;
int boxs = 0;
boxs += s6; // 6*6的产品一个装一箱
boxs += s5; // 5*5的产品一个装一箱
s1 = max(0, s1-11*s5); // 剩余空间用1*1的产品尽量填满
boxs += s4; // 4*4的产品一个装一箱
if(s2<5*s4) s1 = max(0, s1-(5*s4-s2)); // 假如2*2的产品填完之后仍然有空隙,则用1*1填满
s2 = max(0, s2-5*s4); // 尽量用2*2的产品填满
boxs += (s3+3)/4; // 3*3的产品四个一箱
s3 %= 4; // 假如3*3的箱子不是四的倍数个,则先用2*2填充再用1*1填充
if(s3==1){
if(s2<5) s1 = max(0, s1-(27-4*s2));
else s1 = max(0, s1-7);
s2 = max(0, s2-5);
}
else if(s3==2){
if(s2<3) s1 = max(0, s1-(18-4*s2));
else s1 = max(0, s1-6);
s2 = max(0, s2-3);
}
else if(s3==3){
if(s2<1) s1 = max(0, s1-(9-4*s2));
else s1 = max(0, s1-5);
s2 = max(0, s2-1);
}
boxs += (s2+8)/9; // 2*2的产品九个一箱
s2 %= 9; // 假如2*2的箱子不是九的倍数个,则用1*1填充
if(s2) s1 = max(0, s1-(36-4*s2));
boxs += (s1+35)/36; // 1*1的产品三十六个一箱
cout<<boxs<<endl;
}
return 0;
}
poj 1017 装箱子(模拟+贪心)的更多相关文章
- poj 1017 装箱子问题 贪心算法
题意:有1*1到6*6的的东西,需要用6*6的箱子将它们装起来.问:至少需要多少个6*6箱子 思路: 一个瓶子怎么装东西最多?先装石头,在装沙子,然后装水. 同样放在本题就是先装6*6然后5*5... ...
- POJ 2260 Error Correction 模拟 贪心 简单题
Error Correction Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6825 Accepted: 4289 ...
- POJ 1017 Packets【贪心】
POJ 1017 题意: 一个工厂制造的产品形状都是长方体,它们的高度都是h,长和宽都相等,一共有六个型号,他们的长宽分别为 1*1, 2*2, 3*3, 4*4, 5*5, 6*6. 这些产品通常 ...
- POJ - 1017 贪心训练
Packets Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 59725 Accepted: 20273 Descrip ...
- Greedy:Packets(POJ 1017)
装箱问题1.0 题目大意:就是一个工厂制造的产品都是正方形的,有1*1,2*2,3*3,4*4,5*5,6*6,高度都是h,现在要包装这些物品,只能用6*6*h的包装去装,问你怎么装才能使箱子打到最小 ...
- POJ 1017:Packets
Packets Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 47513 Accepted: 16099 Descrip ...
- poj 1017 Packets 裸贪心
Packets Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 43189 Accepted: 14550 Descrip ...
- Poj 1017 Packets(贪心策略)
一.题目大意: 一个工厂生产的产品用正方形的包裹打包,包裹有相同的高度h和1*1, 2*2, 3*3, 4*4, 5*5, 6*6的尺寸.这些产品经常以产品同样的高度h和6*6的尺寸包袱包装起来运送给 ...
- POJ 1922 Ride to School(贪心+模拟)
题意:起点与终点相隔4500米.现Charley 需要从起点骑车到终点.但是,他有个习惯,沿途需要有人陪伴,即以相同的速度, 与另外一个人一起骑.而当他遇到以更快的速度骑车的人时,他会以相应的速度跟上 ...
随机推荐
- 非旋(fhq)Treap小记
前置知识:二叉搜索树 以下摘自 ↑: 二叉搜索树每次操作访问O(深度)个节点. 在刻意构造的数据中,树的形态会被卡成一条链,于是复杂度爆炸 它的复杂度与直接暴力删除类似. 但二叉搜索树扩展性强.更复杂 ...
- Windows下使用SVN版本控制工具
一.SVN工作原理 SVN(SubVersion)的基本工作思路是这样的:在一台服务器上建立一个源代码库,库里可以存放许多不同项目的源程序,由源代码库管理员统一管理这些源程序. 每个用户在使用源代码库 ...
- js跳转页面的方法
js跳转页面的几种方法 第一种:(跳转到b.html) <script language="javascript" type="text/javascript&qu ...
- Buy a Ticket CodeForces - 938D (dijkstra)
大意: n节点无向图, 点$i$到点$j$的花费为$2dis(i,j)+a[j]$, 对于每个点, 求最少花费. 每条边权翻倍, 源点S向所有点$i$连边, 权为$a[i]$, 答案就为$S$到每个点 ...
- 百度地图 echarts tooltip属性 经纬度坐标不显示
中国地图.散点图结合点击后显示当前城市数量 不显示经纬度坐标 echarts.appMap = function (id, opt) { // 实例 var chart = this.init(doc ...
- Thinkphp5.0上传图片与运行python脚本
这里只体现了php可以通过批处理文件调用python脚本的效果 控制器代码 访问路径为127.0.0.1/index/index/upload. index模块,index控制器,upload方法. ...
- C++ 二阶构造模式
1.如何判断构造函数的执行结果? 构造函数没有返回值,所以不能通过返回值来判断是构造函数是否构造成功. 如果给构造函数强行加入一个返回值,用来表示是否构造成功.这样确实能够反映出构造的结果,但是不够优 ...
- 动态表和C++ vector
动态表和C++ vector 最近课上刚刚学了可以根据表中元素的插入和删除动态调整表大小的动态表(dynamic table),就想看一下它有什么实际的应用,第一个想起来的就是C++的vector,直 ...
- loj 2336「JOI 2017 Final」绳
loj 首先,所有位置最多被染色一次,因为要染多次的话,还不如一开始就染成最终的颜色.并且你可以一开始就染好色 因为最终长度为2,那么如果染完后这个序列可以被折完,那么首先最多只有两种颜色,还有就是要 ...
- MySQL中自定义排序
在开发时候,我们经常使用的是默认的排序规则,但在某些特殊情况下,通过指定顺序来进行排序 -- fileld自定义排序时,应该是非主键的,否则主键是无效 SELECT * FROM customer W ...