经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C++ » 查看文章
c++算法之动态规划:01背包
来源:cnblogs  作者:薛晓明c++算法  时间:2023/8/21 8:57:31  对本文有异议

什么是动态规划?

动态规划算法(dynamic programing),是一种由递推为基础的比贪心更稳定的一种优化策略,为运筹学的一部分。就是通过以递推为基础的手段非暴力求出最值

它的总体思想其实就是一个比较过程:假如你有一个数据,它的价值是x,代价为y,如果用动态规划就是和你不加这个元素和你加上这个元素的价值减去他的代价的二值做最值比较

动态规划的思想用的很多就比如:经济上的盈亏、概率等。

今天有于时间关系,只讲零一背包

 

1.01背包问题

零一背包是一种经典的有代价和价值两个元素干涉的最值问题.

 

01背包是在M件物品取出若干件放在空间为W的背包里,每件物品的体积为W1,W2至Wn,与之相对应的价值为P1,P2至Pn。01背包是背包问题中最简单的问题。01背包的约束条件是给定几种物品,

每种物品有且只有一个,并且有权值和体积两个属性。在01背包问题中,因为每种物品只有一个,对于每个物品只需要考虑选与不选两种情况。如果不选择将其放入背包中,则不需要处理。如果选择将其放入背包中,

由于不清楚之前放入的物品占据了多大的空间,需要枚举将这个物品放入背包后可能占据背包空间的所有情况。

但在程序里需要一个二维数组来表达:

首先,什么是状态?

 

状态就是这个二维数组 f[i][j] 表示的什么意思,根据动态规划的思想就可以推出结论:f[i][j]就是第i,j个位置上算出来的最优解

可是,问题来啦,咋求这个最优解呢?于是就必须用到我们的递推试,叫做状态转移方程

 

f[i][j]=max(f[i][j],f[i][j-w[i]]+c[i]);

其中w[i]是代价,c[i]是价值。

so,上代码:

  1. 1 /*
  2. 2 这里就直接出滚动数组优化的代码了
  3. 3 滚动数组就是把前面没最优化的数据覆盖
  4. 4 以达到节省空间的目的。
  5. 5 */
  6. 6 #include<iostream>
  7. 7 using namespace std;
  8. 8 int f[105];
  9. 9 int w[105],c[105];
  10. 10 int main(){
  11. 11 int n,m;
  12. 12 cin >> n>>m;
  13. 13 for(int i=1;i<=n;i++){
  14. 14 cin >> w[i]>> c[i];
  15. 15 }
  16. 16 for(int i=1;i<=n;i++){
  17. 17 for(int j=m;j>=w[i];j--){
  18. 18 f[j]=max(f[j],f[j-w[i]]+c[i]);//滚动数组优化一维
  19. 19 }
  20. 20 }
  21. 21 cout << f[m];
  22. 22 return 0;
  23. 23 }

 

原文链接:https://www.cnblogs.com/xuexue1234/p/dongtaiguihua.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号