[HDU 3535] AreYouBusy (动态规划 混合背包)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3535

题意:有n个任务集合,需要在T个时间单位内完成。每个任务集合有属性,属性为0的代表至少要完成1个,属性为1的为至多完成1个,属性为2的为任意完成。

每个任务做完后都有个价值,问在T个时间单位内完成n个任务集合的任务获得的最大价值是多少?如果不能满足要求输出-1

首先先分析什么情况下输出-1:

因为属性为0的代表至少要完成1个,当遇到一个属性为0的任务集合里一个都无法完成的时候,输出-1.

其他的属性不予考虑,因为其中的每个任务都是可完成可不完成的。

那么问题就归结成为了:属性为0的,是一个分组背包,属性为1的是一个分组背包,属性为2的在组内是一个01背包。

这道题目的好处就是在于深入理解各种背包,我就是不太理解,所以刚开始就敲的各种挫,WA了好多次。

代码:

 1 import java.util.*;
 2
 3 public class Main{
 4     public static void main(String[] args){
 5         Scanner sc = new Scanner(System.in);
 6         while( sc.hasNext() ){
 7             int n = sc.nextInt();
 8             int T = sc.nextInt();
 9             int [][][] c = new int[n+1][111][2];
10
11             for(int i=1;i<=n;i++){
12                 c[i][0][0] = sc.nextInt();
13                 c[i][0][1] = sc.nextInt();
14                 for(int j=1;j<=c[i][0][0];j++){
15                     c[i][j][0] = sc.nextInt();
16                     c[i][j][1] = sc.nextInt();
17                 }
18             }
19
20             int dp[][] = new int[n+1][111];
21
22
23
24             boolean flag = true;
25
26             for(int i=1;i<=n;i++){
27                 if( c[i][0][1]==0 ){
28                     Arrays.fill(dp[i], -99999999);
29                     for(int k=1;k<=c[i][0][0];k++){
30                         for(int j=T;j>=c[i][k][0];j--){
31                             dp[i][j] = Math.max(dp[i][j], Math.max(dp[i-1][j-c[i][k][0]]+c[i][k][1],dp[i][j-c[i][k][0]]+c[i][k][1]));
32                         }
33                     }
34                     if( dp[i][T]<0 ) flag = false;
35                 } else if( c[i][0][1] == 1 ){
36                     for(int j=T;j>=0;j--){
37                         dp[i][j] = dp[i-1][j];
38                         for(int k=1;k<=c[i][0][0];k++){
39                             if( j>=c[i][k][0]) dp[i][j] = Math.max(dp[i][j], dp[i-1][j-c[i][k][0]]+c[i][k][1]);
40                         }
41                     }
42                 } else if( c[i][0][1] == 2 ){
43                     for(int j=T;j>=0;j--){
44                         dp[i][j] = dp[i-1][j];
45                     }
46                     for(int k=1;k<=c[i][0][0];k++){
47                         for(int j=T;j>=c[i][k][0];j--){
48                             dp[i][j] = Math.max(dp[i][j], dp[i][j-c[i][k][0]]+c[i][k][1]);
49                         }
50                     }
51                 }
52
53             } // for i
54
55             if( flag ) System.out.println(dp[n][T]);
56             else System.out.println(-1);
57
58         }
59     }
60 }
时间: 2024-08-09 22:01:41

[HDU 3535] AreYouBusy (动态规划 混合背包)的相关文章

HDU 3535 AreYouBusy (混合背包)

题意:给你n组物品和自己有的价值s,每组有l个物品和有一种类型: 0:此组中最少选择一个 1:此组中最多选择一个 2:此组随便选 每种物品有两个值:是需要价值ci,可获得乐趣gi 问在满足条件的情况下,可以得到的最大的乐趣是多少,如果不能满足条件就输出-1 题解:二维01背包 dp[i][j]:前i组物品我们拥有j的价值时最大可获得的乐趣 0:我们需要先把dp[i]所有赋值为负无穷,这样就只能最少选一个才能改变负无穷 1:我们不需要:dp[i][j-ci]+gi(在此组中再选一个),这样就一定最

HDU 3535 AreYouBusy(组合背包)

传送门 AreYouBusy Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 4362    Accepted Submission(s): 1761 Description Happy New Term!As having become a junior, xiaoA recognizes that there is not much

HDU 3535 AreYouBusy

分组背包 最多取一个的组,则对于该组来说,每一个状态只可能由前一组的状态过来,分不取和取两种 至少取一个,则没了不取的选择,即没有dp[i][j]=dp[i-1][j]的递推式 任意取,即01背包,取法包括由前一组不取或取一个,或由该组取一个 dp[i][j]表示前i组,消耗j时间所能取得的最大值 初值赋为-1,表示该状态不可达,对于dp[0],初值赋为0,即什么都没有的时候最大的快乐值为0 还有一个要注意的点c[k]可能为0,会影响到递推式的顺序 发现做这种混合背包的题非常有助于弄清楚各种背包

hdu 3535 AreYouBusy 混合背包

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3535 题意:有三种任务,至少完成一个,至多完成一个,任意完成.现在给出k组任务,每组任务都属于三种任务的一种.每个任务都会消耗时间,获得幸福感.求时间T内的最大满足感. 三种背包的混合.还是考察对背包问题的理解.显然一维已经满足不了要求了,我们设d[k][j]代表第k组容量为j时获得的最大满足感. 可以明显比较出三种背包的区别.(任意取也就是01背包) 任意取,至少取一种的区别:只取一种的状态是否非

【动态规划】背包九讲及相应习题

[参考博客及视频] 1.大雪菜 2.背包九讲——全篇详细理解与代码实现 3.dd大牛的<背包九讲> 4.背包问题 (附单调队列优化多重背包 [题目] 1.Acwing 背包题目 2.01背包问题 Luogu 2925 干草出售Luogu 1616 疯狂的采药HDU 3466 Proud Merchants 3.完全背包问题 HDU 1114 Piggy-BankLuogu 1853 投资的最大效益 4.多重背包问题 HDU 1059 DividingLuogu P1776 宝物筛选 5.混合背

HDU 3535 分组混合背包

http://acm.hdu.edu.cn/showproblem.php?pid=3535 题意:有n组工作,T时间,每个工作组中有m个工作,改组分类是s,s是0是组内至少要做一件,是1时最多做一件,2时随意,每项工作的描述是花费的时间和获得的快乐值,求在T时间内可获的最大快乐值. memset放错位置了,折腾老半天. 分组混合背包,有的取一件或不取,有的随意,有的最少一个 分三种情况讨论 s==0 考虑前面取过时这次取或不取,前一组取过时这次取或不取 s==1 考虑前一组取过时这次取或不取

动态规划(背包题目)

完全背包 hdu 1248 寒冰王座 hdu 1284 钱币兑换问题 hdu 3732 Ahui Writes Word:将01背包转化为多重背包,即完全背包. 0-1背包 hdu 2546 饭卡:因为要占最大的便宜,所以留5元买最贵的菜,因为每种菜只能买一次,用0-1背包 求出买菜用的最大支出 hdu 3466 Proud Merchants:当钱少于Qi时,不将物品卖出,计算过程中要注意方程无后效性,对 Pi-Qi进行排序,小的排在前面.然后用0-1背包解题,其中的约束条件为拥有的钱不少于Q

3269 混合背包

3269 混合背包 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 背包体积为V ,给出N个物品,每个物品占用体积为Vi,价值为Wi,每个物品要么至多取1件,要么至多取mi件(mi > 1) , 要么数量无限 , 在所装物品总体积不超过V的前提下所装物品的价值的和的最大值是多少? 输入描述 Input Description 第一行两个数N,V,下面N行每行三个数Vi,Wi,Mi表示每个物品的体积,价值与数量,Mi=

HDU 5616 Jam&#39;s balance 背包DP

Jam's balance Problem Description Jim has a balance and N weights. (1≤N≤20)The balance can only tell whether things on different side are the same weight.Weights can be put on left side or right side arbitrarily.Please tell whether the balance can me