POJ 1017 Packet
http://poj.org/problem?id=1017
有1*1 2*2...6*6的物品 要装在 6*6的parcel中 问最少用多少个parcel
一直没有找到贪心的策略
问题应该出现在 总是在想怎么放入parcel中 使得最节省空间
其实这种角度是很麻烦的 情况太多 很难描述清楚
但是其实 放一类型物品 得到的结果是非常具体的
-->>>即从要放的东西的角度出发
放 一个6*6 物品 会占用一个parce
放 一个5*5 物品 会占用一个parce 并且空出11个1*1的空位
放 一个4*4 物品 会占用一个parce 并且空出5个2*2的空位(可以转化为1*1的空位)
放3*3
:放一个 空出 5个2*2的空位 和7个1*1的空位
:放两个 空出 3个2*2的空位 和6个1*1的空位
:放三个 空出 1个2*2的空位 和5个1*1的空位
1*1 和 2*2 的物品作用是用来填补空位的
如果空位被填满 但是物品还未放完 就要再开一个新的parcel
2*2的物品放完后 将所有2*2的空位 变成 1*1的空位
#include <iostream>
#include <string.h>
#include <stdio.h> using namespace std;
//从 六种要装的物品考虑 装每一种物品会空出的空格的情况
int num[];
int main()
{
freopen("in.txt", "r", stdin);
int temp = ;
int parcel = ;
int space[];
while (~scanf("%d", &num[]))
{
temp = ;
temp |= num[];
memset(space, , sizeof(space));
parcel = ;
for (int i = ; i < ; i++)
{
scanf("%d", &num[i]);
temp |= num[i];
}
if (!temp) break;
parcel = num[] + num[] + num[];
space[] = num[] * ;//先解决 6*6,5*5,4*4 的包装盒
space[] = num[] * ;
//解决3*3的盒子
int p3 = , remain = ;
remain = num[] % ;
p3 = remain ? (num[]/)+ : num[]/;//如果还有剩余就多开一个盒子
parcel += p3;
switch(remain)//剩下多少个3*3的物品
{
case : space[] += ; space[] += ;break;
case : space[] += ; space[] += ;break;
case : space[] += ; space[] += ;break;
}
//然后解决 2*2 的盒子
remain = min(num[], space[]);
num[] -= remain;
space[] -= remain;
space[] += space[] * ;
if (num[])
{
remain = num[] % ;
if (remain)//如果还有剩余就多开一个盒子
{
parcel += num[] / + ;
space[] += *(-remain);
}
else
{
parcel += num[] / ;
}
}
//解决1*1
num[] -= min(num[], space[]);
if (num[])
{
remain = num[] % ;
parcel += remain ? num[] / + : num[] / ;//如果还有剩余就多开一个盒子 后面两个逻辑不严密 没有考虑清楚而出错
}
printf("%d\n", parcel);
}
return ;
}
POJ 1017 Packet的更多相关文章
- POJ 1017 Packets【贪心】
POJ 1017 题意: 一个工厂制造的产品形状都是长方体,它们的高度都是h,长和宽都相等,一共有六个型号,他们的长宽分别为 1*1, 2*2, 3*3, 4*4, 5*5, 6*6. 这些产品通常 ...
- POJ 1017
http://poj.org/problem?id=1017 题意就是有6种规格的物品,给你一些不同规格的物品,要求你装在盒子里,盒子是固定尺寸的也就是6*6,而物品有1*1,2*2,3*3,4*4, ...
- Poj 1017 / OpenJudge 1017 Packets/装箱问题
1.链接地址: http://poj.org/problem?id=1017 http://bailian.openjudge.cn/practice/1017 2.题目: 总时间限制: 1000ms ...
- POJ - 1017 贪心训练
Packets Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 59725 Accepted: 20273 Descrip ...
- poj 1017 Packets 裸贪心
Packets Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 43189 Accepted: 14550 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
题意:有一些1×1, 2×2, 3×3, 4×4, 5×5, 6×6的货物,每个货物高度为h,把货物打包,每个包裹里可以装6×6×h,问最少几个包裹. 解法:6×6的直接放进去,5×5的空隙可以用1× ...
- poj 1017 Packets 贪心
题意:所有货物的高度一样,且其底面积只有六种,分别为1*1 2*2 3*3 4*4 5*5 6*6的,货物的个数依次为p1,p2,p3,p4,p5,p6, 包裹的高度与货物一样,且底面积就为6*6,然 ...
- 【递归与分治】 poj 1017
递归与分治经典例题 要点在于对3*3箱子的讨论 #include <iostream> #include <cstdio> using namespace std; in ...
随机推荐
- ubuntu用户自定义的命令alias永久生效
cd ~ vi .bash_profile alias ll='ls -ltr' . .bash_profile ps:写在.bashrc终端断开就没了
- Android提供的对话框
1.普通对话框: 给出提示信息,有yes.no两个按钮. AlertDialog dialog=new AlertDialog.Builder(this) //this代表当前Activity对象,表 ...
- SAP CRM调查问卷的评分和图表显示功能介绍
SAP CRM里我们使用事务码CRM_SURVEY_SUITE创建一个调查问卷(Survey): 其中调查问卷的问题和答案均可分配权值(Rate),最后该问卷总的分数等于每个问题的权值乘以客户选择答案 ...
- 云态(YunCloud)的Centos服务器修改dns教程
DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串.通过主机名,最终 ...
- C# 递归读取XML菜单数据
在博客园注册了有4年了,很遗憾至今仍未发表过博客,趁周末有空发表第一篇博客.小生不才,在此献丑了! 最近在研究一些关于C#的一些技术,纵观之前的开发项目的经验,做系统时显示系统菜单的功能总是喜欢把数据 ...
- (转)使用Spring注解方式管理事务与传播行为详解
http://blog.csdn.net/yerenyuan_pku/article/details/52885041 使用Spring注解方式管理事务 前面讲解了怎么使用@Transactional ...
- how to get many stars on Github?
some key points: 1: make a beautiful README file2: use some GIF (google some tools to convert videos ...
- django模板系统的基本原则
写模板,创建template对象,创建 context ,调用render()方法
- 手工修改注册表激活windows xp法
手工修改注册表激活windows xp法: 1.安装原版windows xp 2.打开注册表regedit 3.找到主键 Hkey_Local_Machine\Software\Microsoft\W ...
- BZOJ2120 数颜色(树套树)
B. 数颜色 题目描述 墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会像你发布如下指令:1. Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色 ...