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 需要从起点骑车到终点.但是,他有个习惯,沿途需要有人陪伴,即以相同的速度, 与另外一个人一起骑.而当他遇到以更快的速度骑车的人时,他会以相应的速度跟上 ...
随机推荐
- [转帖]etcd 在超大规模数据场景下的性能优化
etcd 在超大规模数据场景下的性能优化 阿里系统软件技术 2019-05-27 09:13:17 本文共5419个字,预计阅读需要14分钟. http://www.itpub.net/2019/ ...
- SpringBoot自动化配置之四:@Conditional注解详解
前言 之前在分析spring boot 源码时导出可见@ConditionalOnBean 之类的注解,那么它到底是如何使用的以及其工作流程如何,我们这里就围绕以下几点来分析: @Conditiona ...
- 云数据库 MongoDB版
阿里云云数据库MongoDB版是一种安全可靠.可弹性伸缩的云数据库服务,目前支持ReplicaSet和Sharding两种部署架构,通过简单的几步操作即可快速部署.阿里云云数据库MongoDB版是一种 ...
- Mybatis动态SQL之使用foreach完成复杂查询
一.foreach概述 对于一些SQL语句中含有in条件.需要迭代条件集合来生产的情况,就需要使用foreach标签来实现SQL条件的迭代.foreach主要用在构建in条件中,它可以在SQL语句中迭 ...
- HTML5自学2
1.1 文字格式 一个杂乱无序.堆砌而成的网页,会让人感觉枯无味,而一个美观大方的网页,会让人有美轮美奂,流连忘返的感觉,本节将介绍如何设置网页文本格式. 文字格式包括字体.字号.文字颜色.字体风 ...
- JS中的继承(下)
JS中的继承(下) 在上一篇 JS中的继承(上) 我们介绍了3种比较常用的js继承方法,如果你没看过,那么建议你先看一下,因为接下来要写的内容, 是建立在此基础上的.另外本文作为我个人的读书笔记,才疏 ...
- ELK视频下载
Elasticsearch , Logstash, Kibana 相关视频下载地址:Beats.Elastic Stack.ElasticSearch.Kibana.Logstash下载地址:链接:h ...
- Java LinkedHashMap学习
以前一直使用HashMap,今天学习一下LinkedHashMap JavaDoc 注解: Hash table and linked list implementation of the Map i ...
- 《python解释器源码剖析》第0章--python的架构与编译python
本系列是以陈儒先生的<python源码剖析>为学习素材,所记录的学习内容.不同的是陈儒先生的<python源码剖析>所剖析的是python2.5,本系列对应的是python3. ...
- linux上如何安装postgresql
安装对应的postgresql的yum源 rpm -Uvh https://download.postgresql.org/pub/repos/yum/9.4/redhat/rhel-7-x86_64 ...