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 需要从起点骑车到终点.但是,他有个习惯,沿途需要有人陪伴,即以相同的速度, 与另外一个人一起骑.而当他遇到以更快的速度骑车的人时,他会以相应的速度跟上 ...
随机推荐
- H.Holy Grail ( floyd )(The Preliminary Contest for ICPC Asia Nanjing 2019)
题意: 给出一个有向图,再给出6条原来不存在的路径,让你在这6条路径上添加一个最小的数,使图不存在负环. 思路: 直接6遍 floyd 输出就行了. #include <bits/stdc++. ...
- Sleepy Game CodeForces - 936B
大意: 给定有向图, 初始点S, 两个人轮流移动, 谁不能移动则输, 但后手睡着了, 先手可以控制后手操作, 求最后先手结果. 刚开始看错了, 还以为后手也是最优策略.... 实际上判断是否有偶数个节 ...
- requests与BeautifulSoup
requests模块: 1.安装:pip install requests 2.使用request发送get请求: import requests paras = { 'k1':'c1', 'k2': ...
- Linux(16):Shell编程(3)
vim 编程环境配置: .vimrc 文件配置如下:(.vimrc文件放到家目录下:/root :然后退出 xshell 再登陆进来xshell) set nocompatible set histo ...
- luogu P3620 [APIO/CTSC 2007]数据备份
luogu 首先如果一条线不是了连接的相邻两个位置一定不优,把它拆成若干连接相邻位置的线.所以现在问题是有\(n\)个物品,选\(k\)个,要求选的位置不能相邻,求最小总和 如果没有选的位置不能相邻这 ...
- 查询SAP数据库表的大小
事物代码DB02 Perfomrmance->Additional Functions->SQL Command Editor->写数据表->执行 select bytes/1 ...
- qq游戏IE组件停止工作
你可以下载一个腾讯电脑管家,利用电脑诊所里的腾讯游戏专区里的“网页游 游戏玩不了”这一项修复一下即可.我遇见一次,修复之后就解决了.个人认为是Adobe Flash出问题了.祝你玩的开心.
- paramiko:实现ssh协议,对linux服务器资源的访问
介绍 网络传输是遵循协议的,比如SSH,paramiko则是实现了SSHv2协议的一个python库(底层使用的是cryptography).有了paramiko之后,我们便可以通过python使用s ...
- linux svn 安装
1.环境centos6.4 2.安装svnyum -y install subversion 3.配置 建立版本库目录mkdir /var/www/svndata svnserve -d -r /va ...
- springmvc框架中的核心对象DispatcherServlet
SpringMVC是Spring中的模块,它实现了mvc设计模式,首先用户发起请求,请求到达SpringMVC的前端控制器(DispatcherServlet),前端控制器根据用户的url请求处理器映 ...