【问题描述】

背包是个好东西,希望我也有。
给你一个二维的背包,它的体积是? × ?。现在你有一些大小为1× 2和1×
3的物品,每个物品有自己的价值。你希望往背包里面装一些物品,使得它们的
价值和最大,问最大的价值和是多少。

【输入格式】

第一行一个整数?代表该测试点的数据组数。
对于每组数据,第一行有四个整数?,?,? 1 ,? 2 ,其中? 1 ,? 2 分别代表大小为
1× 2和大小为1 × 3的物品个数。
1 × 2 接下来一行有? 2 个数代表每个1 × 3物品的价值。

【输出格式】

对于每组询问,输出能够达到的价值最大值。

【样例输入】

1
2 3 2 2
1 2
1 2

【样例输出】

4

【样例解释】

庙里有座山,其实就是钟神。

【数据规模与约定】

2,? 1 ,? 2 ≤ 100。

70%的数据,?,? ≤ 100,? 1 ,? 2 ≤ 2000。
对于100%的数据,1 ≤ ? ≤ 10,1 ≤ ?,? ≤ 500,0 ≤ ? 1 ,? 2 ≤ 10000。

思路:

  这题好恶心的我跟你讲;

  做这个题的时候第一个反映是DP,然后风风火火的去打二维背包模板

  打完回来一看傻了眼(这告诉我们要认真读题)

  后来才知道这个题是个前缀和+枚举

  那

  怎么枚举呢?

  这样枚举

  判断体积为3的物品最多能放多少个

  然后从0开始循环到max3

  每次循环都用总体积减去已经放下的体积为3的物品的总体积

  然后记录一下最大的ans就好了

  恩

  这是一个20分的做法

  那

  满分的做法呢?

  满分的做法还要加一个小小的判断

  现在我们想一下,所有的物体不能被拆分或者弯折

  所以物体的长度一定要有足够的空间长度

  但是

  如果背包的长度==2或者背包的宽度==2

  这时长度为3的物品就只能竖着放或者横着放

  如果背包的宽度为2而长度为3的倍数(包括0)+2

  这时最多能放下的体积为3的物体的个数为(n*m-4)/3

  所以

  如果一个背包的满足((m==2||n==2)&&m%3==2&&n%3==2)

  则

  能放下的体积为3的物品的个数为(n*m-4)/3

  说到这基本就可以ac了

  但是

  不要急着去写代码

  还有一个很重要的条件

  就是个数最多不能超过体积为3的物品的总个数

  或者是体积为2的物品的总个数

  来,上代码:

#include<cstdio>
#include<cstring>
#include<algorithm> using namespace std; int T,sum2[],sum3[],n,m,n2,n3;
int min2,min3,max2,max3,sq,ans=,kcc; char ch; void qread(int &x)
{
x=;ch=getchar();
while(ch>''||ch<'') ch=getchar();
while(ch<=''&&ch>=''){x=x*+(int)(ch-'');ch=getchar();}
} bool cmp(int a,int b){return a>b;} int main()
{
qread(T);
while(T--)
{
ans=,min2=,min3=;
qread(n),qread(m),qread(n2),qread(n3);
for(int i=;i<=n2;i++) qread(sum2[i]);
for(int i=;i<=n3;i++) qread(sum3[i]);
sort(sum2+,sum2+n2+,cmp);
sort(sum3+,sum3+n3+,cmp);
for(int i=;i<=n2;i++) sum2[i]+=sum2[i-];
for(int i=;i<=n3;i++) sum3[i]+=sum3[i-];
sq=n*m;
if((n%==&&m%==)&&(n==||m==)) max3=(sq-)/;
else max3=sq/;
int kol=;
max3=min(max3,n3);
for(int i=min3;i<=max3;i++)
{
kol=;
kol+=sum3[i];
kcc=(sq-(i*))/;
kcc=min(n2,kcc);
kol+=sum2[kcc];
ans=max(ans,kol);
}
printf("%d\n",ans);
}
return ;
}

二维背包(钟神想要的)(不是DP)的更多相关文章

  1. NOI 4978 宠物小精灵之收服(二维背包)

    http://noi.openjudge.cn/ch0206/4978/ 描述 宠物小精灵是一部讲述小智和他的搭档皮卡丘一起冒险的故事. 一天,小智和皮卡丘来到了小精灵狩猎场,里面有很多珍贵的野生宠物 ...

  2. hdu 4501 小明系列故事——买年货_二维背包

    题目:你可以有v1元,v2代金券,v3个物品免单,现在有n个商品,商品能用纸币或者代金券购买,当然你可以买v3个商品免费.问怎么最大能买多少价值 题意: 思路二维背包,dp[v1][v2][v3]=M ...

  3. HDU 2159 FATE (二维背包)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2159 解题报告:这题实际上是一个二维的背包问题,也可以由01背包扩展而来,01背包用一维数组,可想而知 ...

  4. rqnoj-329-刘翔!加油!-二维背包

    注意排除干扰项. 因为价值不会相等,所以价值的多少与本题没有任何关系,. 所以价值为干扰项,所以不用考虑. 二维背包,简单求解. #include<stdio.h> #include< ...

  5. dp之二维背包poj2576

    题意:有一群sb要拔河,把这群sb分为两拨,两拨sb数只差不能大于1,输出这两拨人的体重,小的在前面...... 思路:把总人数除2,总重量除2,之后你会发现就是个简单的二维背包,有两个限制..... ...

  6. hdu 3496 Watch The Movie (二维背包)

    Watch The Movie Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)T ...

  7. 二维背包---P1509 找啊找啊找GF

    P1509 找啊找啊找GF 题解 很明显这是一道二维背包题目 如果一个dp数组做不了,那么我们就再来一个dp数组 题目要求,花费不超过 m ,消耗人品不超过  r  ,泡到尽量多的妹子,时间尽量少 f ...

  8. 二维背包---P1855 榨取kkksc03

    P1855 榨取kkksc03 题解 二维背包板子题 f[ i ][ j ] 前 n 个物品,花费金钱不超过 i ,花费时间不超过 j 的最大价值 如果每个物品只能选一次,那么就相当于在01背包上多加 ...

  9. 01二维背包——poj2576

    /* 要求把a数组分成两个集合,两个集合人数最多差1,并且元素之和的差尽可能小 那只要把所有可行的列出来即可 01二维背包,即体积是个二维数据,那么我们的背包状态也应该设为二维 dp[j][k]设为 ...

随机推荐

  1. mysql服务器的字符集

    文章:http://www.cnblogs.com/fantiantian/p/3468454.html 的评论中有这样的文字: 谢谢沧海一滴的总结 在Linux中一般都是UTF-8字符集.我们在建数 ...

  2. [vim] vim入门

    1. 概述 工欲善其事 必先利其器.vim是非常好用的文本编辑器,可以将它看作是vi的进阶.绝大多数Unix系统都会内置vi编辑器,vi是文本编辑器,vim是程序编辑器.相比vi,它可以根据文件的类型 ...

  3. 美丽的阴影(剖析jquery主页)

    jquery Download API Documentation Blog Plugins Browser Support jquery主页第一眼看到的就是这个玻璃渣效果,设计者利用高光和阴影制造出 ...

  4. javascript数组浅谈2

    上次说了数组元素的增删,的这次说说数组的一些操作方法 join()方法: ,,] arr.join("_") //1_2_3 join方法会返回一个由数组中每个值的字符串形式拼接而 ...

  5. “连不上 ArcGIS License Manager ”的一点常用诊断方法

    在 ArcGIS Desktop 的问题库中,有一类不算做核心技术问题,但却可能会位列“最常见的问题”之一.简言之一句话,”许可服务器连不上怎么办?!“ 下面就来演绎下问题的诊断过程. 本文仅适用于客 ...

  6. Android Sqlite 实例入门

    通过一个简单的例子来学习Sqlite,学生选课系统,一开始的需求是学生可以选课,选课完成后可以查询到已经选择的课. 首先设计三个表,学生,课程,选课.学生表存储学生的信息,课程表存储课程的信息,选课表 ...

  7. HTML5 -1- 简介

    在介绍HTML5之前我们应该先了解一下HTML5 我想从下面开始简单了解一下HTML5 什么是HTML5??? HTML5 即HTML 5.0 版本 正式制定时间是在2014年 遵循着移动先行(前四个 ...

  8. 我的android学习经历11

    让TextViews实现跑马灯效果 有时候用文本控件时,文本只能在一行显示,而且文本很长的话,后面的文本就会隐藏 一.假如你只需要一个TextView,那个可以添加三个属性实现跑马灯效果,也就是让文字 ...

  9. 我为什么用 SQLite 和 FMDB 而不用 Core Data

    凭良心讲,我不能告诉你不去使用Core Data.它不错,而且也在变好,并且它被很多其他Cocoa开发者所理解,当有新人加入你的组或者需要别人接手你的项目的时候,这点很重要.更重要的是,不值得花时间和 ...

  10. javascript 自定义类型 属性,方法

    <html> <head> <script type="text/javascript"> function member(name,gende ...