博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu4501——小明系列故事——买年货(多维背包)
阅读量:5103 次
发布时间:2019-06-13

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

题解:

思路:将v1,v2,k都当作一种体积,开三维dp数组,每种物品只能取一次

 

代码中的for循环是倒着进行的,知道01背包和完全背包的肯定明白,倒着进行的就代表每种物品只选择一次

代码:

1 #include
2 #include
3 #include
4 #include
5 using namespace std; 6 const int maxn=105; 7 const int INF=0x3f3f3f3f; 8 int dp[maxn][maxn][6]; 9 struct shudui10 {11 int a,b,val;12 } m[maxn];13 int main()14 {15 int n,v1,v2,k1;16 while(~scanf("%d%d%d%d",&n,&v1,&v2,&k1))17 {18 for(int i=1; i<=n; ++i)19 {20 scanf("%d%d%d",&m[i].a,&m[i].b,&m[i].val);21 }22 memset(dp,0,sizeof(dp));23 for(int l=1; l<=n; ++l)24 {25 for(int i=v1; i>=0; --i)26 {27 for(int j=v2; j>=0; --j)28 {29 for(int k=k1; k>=0; --k)30 {31 int temp=0;32 if(i-m[l].a>=0)33 temp=max(temp,dp[i-m[l].a][j][k]+m[l].val);34 if(j-m[l].b>=0)35 temp=max(temp,dp[i][j-m[l].b][k]+m[l].val);36 if(k>0)37 temp=max(temp,dp[i][j][k-1]+m[l].val);38 dp[i][j][k]=max(dp[i][j][k],temp);39 }40 }41 }42 }43 printf("%d\n",dp[v1][v2][k1]);44 }45 return 0;46 }
View Code

 

 

其实感觉多维背包也是一种套路,主要是找到dp的维度

转载于:https://www.cnblogs.com/kongbursi-2292702937/p/11189487.html

你可能感兴趣的文章
编写一个简单的JAVA WEB Servlet页面
查看>>
JSP:Cookie实现永久登录(书本案例)
查看>>
js window.open 参数设置
查看>>
032. asp.netWeb用户控件之一初识用户控件并为其自定义属性
查看>>
linux--GCC用法
查看>>
Ubuntu下安装MySQL及简单操作
查看>>
OWIN是什么?
查看>>
前端监控
查看>>
centos6.5 mysql忘记登入密码
查看>>
Trusted Execution Technology (TXT) --- 启动控制策略(LCP)篇
查看>>
clipboard.js使用方法
查看>>
绘图库:Matplotlib
查看>>
0906第一次作业
查看>>
Ceph Monitor基础架构与模块详解
查看>>
dbca:Exception in thread "main" java.lang.UnsatisfiedLinkError: get
查看>>
hdu 1232 畅通工程(并查集)
查看>>
移动开发平台-应用之星app制作教程
查看>>
jquery validate使用笔记
查看>>
主要的几个脑网络——整理自eegfmri的博客
查看>>
leetcode 459. 重复的子字符串(Repeated Substring Pattern)
查看>>