题目描述

金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己专用的很宽敞的房间。更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过NNN元钱就行”。今天一早,金明就开始做预算了,他把想买的物品分为两类:主件与附件,附件是从属于某个主件的,下表就是一些主件与附件的例子:

主件 附件

电脑 打印机,扫描仪

书柜 图书

书桌 台灯,文具

工作椅 无

如果要买归类为附件的物品,必须先买该附件所属的主件。每个主件可以有000个、111个或222个附件。附件不再有从属于自己的附件。金明想买的东西很多,肯定会超过妈妈限定的NNN元。于是,他把每件物品规定了一个重要度,分为555等:用整数1−51-51−5表示,第555等最重要。他还从因特网上查到了每件物品的价格(都是101010元的整数倍)。他希望在不超过NNN元(可以等于NNN元)的前提下,使每件物品的价格与重要度的乘积的总和最大。

设第jjj件物品的价格为v[j]v_[j]v[​j],重要度为w[j]w_[j]w[​j],共选中了kkk件物品,编号依次为j1,j2,…,jkj_1,j_2,…,j_kj1​,j2​,…,jk​,则所求的总和为:

v[j1]×w[j1]+v[j2]×w[j2]+…+v[jk]×w[jk]v_[j_1] \times w_[j_1]+v_[j_2] \times w_[j_2]+ …+v_[j_k] \times w_[j_k]v[​j1​]×w[​j1​]+v[​j2​]×w[​j2​]+…+v[​jk​]×w[​jk​]。

请你帮助金明设计一个满足要求的购物单。

输入输出格式

输入格式:

第111行,为两个正整数,用一个空格隔开:

NmN mNm
(其中N(<32000)N(<32000)N(<32000)表示总钱数,m(<60)m(<60)m(<60)为希望购买物品的个数。)
从第222行到第m+1m+1m+1行,第jjj行给出了编号为j−1j-1j−1的物品的基本数据,每行有333个非负整数

vpqv p qvpq
(其中vvv表示该物品的价格(v<10000v<10000v<10000),p表示该物品的重要度(1−51-51−5),qqq表示该物品是主件还是附件。如果q=0q=0q=0,表示该物品为主件,如果q>0q>0q>0,表示该物品为附件,qqq是所属主件的编号)

输出格式:

一个正整数,为不超过总钱数的物品的价格与重要度乘积的总和的最大值(<200000<200000<200000)。

输入输出样例

输入样例#1:
复制

  1. 1000 5
  2. 800 2 0
  3. 400 5 1
  4. 300 5 1
  5. 400 3 0
  6. 500 2 0
输出样例#1: 复制

  1. 2200

说明

NOIP 2006 提高组 第二题

题解

算是分组背包的模板题了叭?

设主件为1,附件为2,3,

那么将{1},{1,2},{1,3},{1,2,3}视为同组内的物件,同组内至多只能选1个。

//如果只有一个附件,组内就是{1},{1,2};如果没有附件,组内就是{1}。

跑分组背包就行了。

关于分组背包:

因为和01一样只有选和不选的区别,不像完全背包可以无限选,

所以容积也是要从大到小循环。

然后在一组里面只能选一个,所以干脆一组一组的跑,

在每一组里面循环容积,在容积里面再循环每件物品,就可以保证是由不含该组物品的状态转移而来了。

  1. /*
  2. qwerta
  3. P1064 金明的预算方案
  4. Accepted
  5. 100
  6. 代码 C++,1.19KB
  7. 提交时间 2018-10-17 09:46:49
  8. 耗时/内存
  9. 49ms, 932KB
  10. */
  11. #include<iostream>
  12. #include<cstdio>
  13. using namespace std;
  14. struct emm{
  15. int w,v,f,lson,rson;
  16. }a[];//w:费用 v:价值 f:父节点
  17. struct ahh{
  18. int w,v;
  19. }b[];//分组用的
  20. int f[];//dp数组
  21. int main()
  22. {
  23. //freopen("a.in","r",stdin);
  24. int n,m;
  25. scanf("%d%d",&n,&m);
  26. for(int i=;i<=m;++i)
  27. {
  28. int v,p,fa;
  29. scanf("%d%d%d",&v,&p,&fa);
  30. a[i].w=v;
  31. a[i].v=v*p;
  32. a[i].f=fa;
  33. if(fa)
  34. {
  35. if(!a[fa].lson)
  36. a[fa].lson=i;
  37. else
  38. a[fa].rson=i;
  39. }
  40. }
  41. for(int k=;k<=m;++k)//枚举每组
  42. if(!a[k].f)//如果该件为主件(代表一个组)
  43. {
  44. int kk=;
  45. //分组,存在b里
  46. b[++kk]=(ahh){a[k].w,a[k].v};//
  47. if(a[k].lson)
  48. {
  49. b[++kk]=(ahh){a[k].w+a[a[k].lson].w,a[k].v+a[a[k].lson].v};//1,2
  50. if(a[k].rson)
  51. {
  52. b[++kk]=(ahh){a[k].w+a[a[k].rson].w,a[k].v+a[a[k].rson].v};//1,3
  53. b[++kk]=(ahh){a[k].w+a[a[k].lson].w+a[a[k].rson].w
  54. ,a[k].v+a[a[k].lson].v+a[a[k].rson].v};//1,2,3
  55. }
  56. }
  57. //cout<<k<<" "<<kk<<endl;
  58. for(int v=n;v;--v)//从大到小枚举容积
  59. for(int i=;i<=kk;++i)//循环组内元素
  60. if(v-b[i].w>=)
  61. f[v]=max(f[v],f[v-b[i].w]+b[i].v);
  62. }
  63. cout<<f[n];//输出
  64. return ;
  65. }

「NOIP2006」「LuoguP1064」 金明的预算方案(分组背包的更多相关文章

  1. [LuoguP1064][Noip2006]金明的预算方案

    金明的预算方案(Link) 题目描述 现在有\(M\)个物品,每一个物品有一个钱数和重要度,并且有一个\(Q\),如果\(Q = 0\),那么该物件可以单独购买,当\(Q != 0\)时,表示若要购买 ...

  2. [codevs1155][KOJ0558][COJ0178][NOIP2006]金明的预算方案

    [codevs1155][KOJ0558][COJ0178][NOIP2006]金明的预算方案 试题描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己专用的很宽敞的房间.更让他高兴 ...

  3. Luogu 1064 金明的预算方案 / CJOJ 1352 [NOIP2006] 金明的预算方案(动态规划)

    Luogu 1064 金明的预算方案 / CJOJ 1352 [NOIP2006] 金明的预算方案(动态规划) Description 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己 ...

  4. NOIP2006 金明的预算方案

    1.             金明的预算方案 (budget.pas/c/cpp) [问题描述] 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己专用的很宽敞的房间.更让他高兴的是,妈 ...

  5. 【洛谷P1064】[NOIP2006] 金明的预算方案

    金明的预算方案 显然是个背包问题 把每个主件和它对应的附件放在一组,枚举每一组,有以下几种选法: 1.都不选 2.只选主件 3.一个主件+一个附件 4.一个主件+两个附件 于是就成了01背包.. #i ...

  6. tyvj 1057 金明的预算方案 背包dp

    P1057 金明的预算方案 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 NOIP2006 提高组 第二道 描述 金明今天很开心,家里购置的新房就要领钥匙了 ...

  7. NOIP 2006 金明的预算方案

    洛谷 P1064 金明的预算方案 https://www.luogu.org/problem/P1064 JDOJ 1420: [NOIP2006]金明的预算方案 T2 https://neooj.c ...

  8. 动态规划(背包问题):HRBUST 1377 金明的预算方案

    金明的预算方案 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过N元钱就行 ...

  9. 算法笔记_103:蓝桥杯练习 算法提高 金明的预算方案(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些 ...

随机推荐

  1. freemark2pdf

    freemarker+ITextRenderer 生成html转pdf 博客分类: ITextRenderer ITextRenderer  网上已经有比较多的例子 写这个 但是很多都是简单的 dem ...

  2. easyNetq demo

    本demo包含一个类库,2个console程序 1.新建类库  MQHelper,控制台程序  consumer和proc ,控制台程序引用MQHelper 2.使用nuget安装easynwtq 和 ...

  3. Xenomai PC开发环境

    这两天总在纠结编译一个PC机上的Xenomai开发环境,选择编译器.kernel版本和IPIP版本,但是今天忽然想到,上位机只是个开发环境,只要能编译.能运行就可以了,实时性根本不是关注的东西.而Xe ...

  4. 49 个jquery代码经典片段

    49 个jquery代码经典片段,这些代码能够给你的javascript项目提供帮助.其中的一些代码段是从jQuery1.4.2才开始支持的做法,另一 些则是真正有用的函数或方法,他们能够帮助你又快又 ...

  5. sigar 监控服务器硬件信息

    转载 http://www.cnblogs.com/jifeng/archive/2012/05/16/2503519.html 通过使用第三方开源jar包sigar.jar我们可以获得本地的信息 1 ...

  6. opensearch空查询

    query子句不支持为空的查询,可以使用filter子句:filter=area=""   或者 filter=filedlen(area)=0 可以使用相关性函数实现:https ...

  7. create-react-app创建项目报错SyntaxError: Unexpected end of JSON input while parsing near '...ttachment":false,"tar' npm代理

    SyntaxError: Unexpected end of JSON input while parsing near '...ttachment":false,"tar' 错误 ...

  8. Android中的android:layout_width和android:width

    最近在看android的东西,发现很多和web前台的东西一样(思想).只是看到很多属性的写法和前台有差别,刚刚看到这样的属性: android:width 其实是定义控件上面的文本(TextView) ...

  9. EasyPlayerPro Windows流媒体播放器(RTSP/RTMP/HTTP/HLS/File/TCP/RTP/UDP都能播)发布啦

    EasyPlayerPro简介 EasyPlayerPro是一款全功能的流媒体播放器,支持RTSP.RTMP.HTTP.HLS.UDP.RTP.File等多种流媒体协议播放.支持本地文件播放,支持本地 ...

  10. Golang 环境变量及工作区概念

    GOROOT go的安装路径 GOPATH 可以有多个目录,每个目录就是一个工作区,放置源码文件,以及安装后的归档文件和可执行文件: 第一个工作区比较重要,go get会自动从一些主流公用代码仓库下载 ...