博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 2546 饭卡(01 背包)
阅读量:6296 次
发布时间:2019-06-22

本文共 1145 字,大约阅读时间需要 3 分钟。

链接:http://acm.hdu.edu.cn/showproblem.php?pid=2546

思路:需要首先处理一下的的01背包,当饭卡余额大于等于5时,是什么都能买的,所以题目要饭卡余额最小,那预留5元(相当于饭卡余额为5)来买最贵的菜

然后对剩下n-1进行01背包dp才是正确的。但是还存在一个问题,那就饭卡初始余额小于5时,也要处理掉。

下面讲01背包(原型可以看大牛的背包九讲,本人也正在学习),定义dp[i][j]为买前i种菜品剩下j元时的最大消费值等于下面两中情况之一的值

有两种来源,对于第i种菜品,可买或者不买

1.买的话就是dp[i-1][j-p[i]]+p[i],前i-1种菜品剩j-p[i]元的最大消费值+第i种菜品的消费值

2.不买的话就是dp[i-1][j],前i-1种菜品剩j元的最大消费值

则状态转移方程为:

dp[i][j] = max(dp[i-1][j],dp[i-1][j-p[i]]+p[i])

我们看到i的状态是由i-1得来的,则可以用一维数组来降低空间复杂度

但是如果j顺序循环的话,j是由(i-1时的j和j-p[i])的得来,顺推的时候,j-p[i]这个状态已经发生了改变,不再是(i-1)时的了,而是i的状态了。

采用逆推明显可以避免覆盖问题

一维表示就是 dp[j] = max(dp[j],dp[j-p[i]]+p[i])

下面看代码吧

1 ///具体是先判断m是否小于5,大于等于5的话就按升序排序,对前n-1菜品,m-5的余额使用01背包dp 2 #include
3 #include
4 #include
5 #include
6 using namespace std; 7 int dp[1010],p[1010]; 8 int main() 9 {10 int n,m;11 while(scanf("%d",&n)&&n)12 {13 for(int i = 0; i
=a[i]; j--)26 dp[j] = max(dp[j],dp[j-p[i]]+p[i]);27 printf("%d\n",m-maxv-dp[m-5]);28 }29 return 0;30 }

 

转载于:https://www.cnblogs.com/jiachinzhao/p/4550644.html

你可能感兴趣的文章
sqoop数据迁移(基于Hadoop和关系数据库服务器之间传送数据)
查看>>
腾讯云下安装 nodejs + 实现 Nginx 反向代理
查看>>
Javascript 中的 Array 操作
查看>>
java中包容易出现的错误及权限问题
查看>>
AngularJS之初级Route【一】(六)
查看>>
服务器硬件问题整理的一点总结
查看>>
SAP S/4HANA Cloud: Revolutionizing the Next Generation of Cloud ERP
查看>>
Mellanox公司计划利用系统芯片提升存储产品速度
查看>>
白帽子守护网络安全,高薪酬成大学生就业首选!
查看>>
ARM想将芯片装进人类大脑 降低能耗是一大挑战
查看>>
Oracle数据库的备份方法
查看>>
Selenium 自动登录考勤系统
查看>>
关于如何以编程的方式执行TestNG
查看>>
智能照明造福千家万户 家居智能不再是梦
查看>>
物联网如何跳出“看起来很美”?
查看>>
浅谈MySQL 数据库性能优化
查看>>
《UNIX/Linux 系统管理技术手册(第四版)》——1.10 其他的权威文档
查看>>
灵动空间 创享生活
查看>>
《UNIX网络编程 卷1:套接字联网API(第3版)》——8.6 UDP回射客户程序:dg_cli函数...
查看>>
不要将时间浪费到编写完美代码上
查看>>