
POJ - 1276 二进制优化多重背包为01背包
发布日期:2021-05-06 14:14:31
浏览次数:16
分类:精选文章
本文共 600 字,大约阅读时间需要 2 分钟。
题意:直接说数据,735是目标值,然后3是后面有三种钱币,四张125的,六张五块的和三张350的。
思路:能够轻易的看出这是一个多重背包问题,735是背包的容量,那些钱币是物品,而且有一定的数量,是多种背包。但是做的时候总是超时。可能是因为m和n太大。然后可以通过二进制把它转化为01背包,因为将钱币的数量化为二进制,1 2 4直到数量减一。化成的二进制数字排列组合,可以组成任意钱币数量内的数字。
看代码:
//二进制优化 多重背包转化为01背包#includeint main(){ int cash,s[100010],n; int dp[100010]; while(~scanf("%d%d",&cash,&n)) { for(int i=0;i<=cash;i++) dp[i]=0; int k=0,a,b; for(int i=0;i =s[i];j--) { dp[j]=dp[j]>dp[j-s[i]]+s[i]?dp[j]:dp[j-s[i]]+s[i]; } } printf("%d\n",dp[cash]); } return 0;}
发表评论
最新留言
路过按个爪印,很不错,赞一个!
[***.219.124.196]2025年03月25日 17时37分18秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
invalid byte sequence for encoding
2019-03-05
redis向数组中添加值并查看数组长度
2019-03-05
JS编写一个函数,计算三个不同数字的大小,按从小到大顺序打印(穷举法)
2019-03-05
sqlplus的基本使用
2019-03-05
Oracle常用SQL
2019-03-05
技术美术面试问题整理
2019-03-05
C++学习记录 五、C++提高编程(2)
2019-03-05
4 Java 访问控制符号的范围
2019-03-05
VUE3(八)setup与ref函数
2019-03-05
智能合约开发实践(1)
2019-03-05
MATLAB——操作矩阵的常用函数
2019-03-05
CMake自学记录,看完保证你知道CMake怎么玩!!!
2019-03-05
ORB-SLAM2:LoopClosing线程学习随笔【李哈哈:看看总有收获篇】
2019-03-05
牛客练习赛56 D 小翔和泰拉瑞亚(线段树)
2019-03-05
NC15553 数学考试(线性DP)
2019-03-05
MySQL隐藏文件.mysql_history风险
2019-03-05
js求阶乘
2019-03-05
小程序图片正确使用方式(防止发布之后不显示)
2019-03-05