[hdu1712]ACboy needs your help分组背包

题意:一共$m$天,$n$门课程,每门课程花费$i$天得到$j$的价值,求最后获得的最大价值

解题关键:分组背包练习,注意循环的顺序不能颠倒

伪代码:

$for$ 所有的组$k$
   $for{\rm{ }}v = V..0$
        $for$ 所有的$i$属于组$k$
           $f[v] = \max (f[v],f[v - c[i]] + w[i])$

背包问题本质上就是一种线性规划问题。

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 typedef long long ll;
 4 int arr[200][200];
 5 int dp[200];
 6 int main(){
 7     int n,m;
 8     ios::sync_with_stdio(0);
 9     while(cin>>n>>m&&(n||m)){
10         memset(dp,0,sizeof dp);
11         for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) cin>>arr[i][j];
12         for(int i=1;i<=n;i++){
13             for(int j=m;j>=0;j--){
14                 for(int k=1;k<=j;k++){
15                     dp[j]=max(dp[j],dp[j-k]+arr[i][k]);
16                 }
17             }
18         }
19         cout<<dp[m]<<"\n";
20     }
21     return 0;
22 }

 

转载于:https://www.cnblogs.com/elpsycongroo/p/7407416.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值