一.题目链接:P1064 金明的预算方案

二.思路

1.一共只有五种情况

@1.不买

@2.只买主件

@3.买主件和附件1(如果不存在附件也要运算,只是这时附件的数据是0,也就是算了对标准的结果也没影响)

@4.买主件和附件2

@5.买主件和两个附件

2.因为要求的是重要度*价格,那么数组就直接存重要度*价格,最后输出f[n]就是答案

附件不一定刚好有两个,可是如果没有的话数组的值是空的,也就好像虚无缥缈的灵魂一样,用了也没关系

3.主件和附件要构建一层联系,一个个输入物品时肯定混杂着主件和附件,那么对于主件数组,如果编号为0就存,编号不为0就让他空着,对于附件数组,就用编号作为下标就好了,这样就在主件和附件中构建一层联系,可以随时通过主件找到所属附件

4.判断各种情况时要考虑能不能执行,也就是剩余金币够不够的问题

5.然后循环的时候用滚动数组优化空间,不懂的可以去了解一下

6.各种情况都比较一次,找出最好的就好了

7.本来存重要度的数组现在存重要度*价格,可以简化代码

三.代码

#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll f[+];
ll main_v[+];//v主件单个价格
ll main_vp[+];//主件单个重要度p*价格v
ll belong_v[+][];//附件价格v
ll belong_vp[+][];//附件重要度p*价格v
int main()
{
std::ios::sync_with_stdio(false);
ll n,m;//n钱,m总数
ll temp_v,temp_p,temp_kind;
cin>>n>>m;
for(ll i=;i<=m;i++)
{
cin>>temp_v>>temp_p>>temp_kind;
if(temp_kind==)//如果编号为0,则是物品
{
main_v[i]=temp_v;
main_vp[i]=temp_v*temp_p;
}
else//如果是附属品
{
belong_v[temp_kind][]++;//判断现在是第几个附件,用belong_v[temp_kind][0]来存
belong_v[ temp_kind ][ belong_v[temp_kind][] ] = temp_v;
belong_vp[ temp_kind ][ belong_v[temp_kind][] ] = temp_v*temp_p;
}
}
for(ll i=;i<=m;i++)
for(ll j=n;j>=main_v[i]&&main_v[i]!=;j--)//如果main_v[i]==0则说明这个位置放的是附件
{//如果没进入这个地方就是什么也没买
f[j]=max(f[j],f[j-main_v[i]]+main_vp[i]);//只买主件或者不买
//接下来不能用else if呀,因为是各种情况中的比较
if(j-main_v[i]-belong_v[i][]>=)//买主件和附件1
f[j]=max(f[j],f[j-main_v[i]-belong_v[i][]] + main_vp[i]+belong_vp[i][]);
if(j-main_v[i]-belong_v[i][]>=)//买主件和附件2
f[j]=max(f[j],f[j-main_v[i]-belong_v[i][]] + main_vp[i]+belong_vp[i][]);
if(j-main_v[i]-belong_v[i][]-belong_v[i][]>=)//买主件和附件1和附件2
f[j]=max(f[j],f[j-main_v[i]-belong_v[i][]-belong_v[i][]] + main_vp[i]+belong_vp[i][]+belong_vp[i][]);
}
cout<<f[n]<<endl;
}

金明的预算方案

四.我没想出来的原因

1.我第一种思路是,标记主件有没有被选,但是在动态规划中标记法是不可行的,而且最好不要回溯

2.我第二种思路是,先判断主件,再判断附件,可是这样没什么实际意义,因为主件会对后面的附件产生后效性

3.我一直的疑惑是:判断主件和附件1都有的时候算一种,那么判断主件和附件2都有的时候,怎么知道主件有没有被买过,其实这里就差一点了,只要再考虑同时被买就好了,因为最多才两个附件,其实这是有暗示的:最多两个附件,两个那么小的数字,只有四种情况,完全可以组合出来

4.看懂思路之后我还是WA了一次,错在细节,就是附件的下标应该用temp_kind而不是i,因为附件的下标是紧跟主件的,也就是他们之间要有一个东西,一条纽带能连接

5.又错了一个细节,就是我写了这样的东西f[j]=f[j-main_v[i]]+main_vp[i]这的意思是能买就一定买,是错的,应该是能买再考虑买不买

NOIP 2006 金明的预算方案(洛谷P1064,动态规划递推,01背包变形,滚动数组)的更多相关文章

  1. NOIP 2006 金明的预算方案

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

  2. 最大子段和(洛谷P1115,动态规划递推)

    洛谷题目链接 题目赋值出来格式有问题,所以我就只放题目链接了 下面为ac代码 #include<bits/stdc++.h> #define ll long long using name ...

  3. P1060 开心的金明(洛谷,动态规划递推,01背包轻微变形题)

    题目链接:P1060 开心的金明 基本思路: 基本上和01背包原题一样,不同点在于这里要的是最大重要度*价格总和,我们之前原题是 f[j]=max(f[j],f[j-v[i]]+p[i]); 那么这里 ...

  4. NOIP 2008 传纸条(洛谷P1006,动态规划递推,滚动数组)

    题目链接:P1006 传纸条 PS:伤心,又想不出来,看了大神的题解 AC代码: #include<bits/stdc++.h> #define ll long long using na ...

  5. P1048 采药(洛谷,动态规划递推,01背包原题)

    题目直接放链接 P1048 采药 这题只是01背包+背景故事而已 原题来的 PS:我写了一篇很详细的01背包说明,如果下面ac代码有看不懂的地方可以去看看 对01背包的分析与理解(图文) 下面上ac代 ...

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

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

  7. 「NOIP2006」「LuoguP1064」 金明的预算方案(分组背包

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

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

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

  9. NOIP2006 金明的预算方案

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

随机推荐

  1. 视频生成 量产 win 转 linux ffmpeg linux 安装 对批量视频的尽可能短时间生成

    环境准备 Welcome to aliyun Elastic Compute Service! [root@mytest ~]# pip install baidu-aip Looking in in ...

  2. rabbitmq最大连接数(Socket Descriptors)

    RabbitMQ自带了显示能够接受的最大连接数,有2种比较直观的方式:1. rabbitmqctl命令. 1 2 3 4 5 6 7 8 9 10 11 12 <span style=" ...

  3. phpstorm配置php脚本执行

    1.到设置中配置 2.配置具体项 3.完了就可以执行php脚本了

  4. hdoj--2186--悼念512汶川大地震遇难同胞——一定要记住我爱你(模拟水题)

     悼念512汶川大地震遇难同胞--一定要记住我爱你 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (J ...

  5. bzoj1778

    高斯消元+矩阵的逆 来自popoqqq大神 求矩阵的逆:把I-T放在左边,P/Q*S放在右边,这样就形成了一个n*2n的矩阵,然后把左边高斯消元,右边就是求完逆的矩阵,其实就是ans,矩阵的逆跟乘法逆 ...

  6. Python Matplotlib模块--pyplot

    #-*- coding: utf- -*- ''' numpy.linspace(start, stop, num=50, endpoint=True, retstep=False, dtype=No ...

  7. Java setAccessible方法作用

    在Java中可以通过反射进行获取实体类中的字段值,当未设置Field的setAccessible方法为true时,会在调用的时候进行访问安全检查,会抛出IllegalAccessException异常 ...

  8. bzoj 1622: [Usaco2008 Open]Word Power 名字的能量【模拟】

    模拟即可,注意包含可以是不连续的 方便起见读入的时候全转成小写 #include<iostream> #include<cstdio> using namespace std; ...

  9. 17年day5

    /* 嗯,一切都快要结束了. 觉得不必要写太多,从day5开始就挺好吧. 记得去年这时候看到峰峰博客里的倒计时,心里还毫无波动,只是走的时候挺伤心. 现在轮到了我们. 峰峰我想你. 衷心祝zjk和my ...

  10. Agar.io 简单但是有趣的网页游戏

    攻略,进阶 上榜第一次 (有点水,九百多分)  上榜第二次 (完成四杀,逆袭上榜) 上榜第三次 (忘写名字,自己补上) 上榜第四次 (人生巅峰!) 上榜第五次 (踩了狗屎运,上榜这么容易了?收了一个小 ...