hdu3535:http://acm.hdu.edu.cn/showproblem.php?pid=3535

该题是非常全面的一道分组背包问题。其实理解了最多一个的分组背包问题,解题起来也是很简单的。但是该题卡了我3天,真让人郁闷。就是因为一个case过不了,里面的时间ci可以为0!!!测试数据中竟然有0分钟这种事情!!!

  题解:

  

#include<iostream>
#include<cstdio>
#include<cstring>
#include<vector>
using namespace std;
int dp[][+];
typedef struct Job
{
int ci;
int gi;
}Job;
int main()
{
int n,t;
while(~scanf("%d%d",&n,&t))
{
int s[n];
vector<Job> vjob[n];
for(int i=;i<n;++i)
{
int m;
scanf("%d%d",&m,&s[i]);
for(int j=;j<m;++j)
{
Job job;
scanf("%d%d",&job.ci,&job.gi);
vjob[i].push_back(job);
}
}
memset(dp,,sizeof(dp));
for(int i=;i<n;++i)
{
memcpy(dp[],dp[],sizeof(dp[]));
//最少1
if(s[i]==)
{
memset(dp[],-,sizeof(dp[]));
for(int j=;j<vjob[i].size();++j)
{
for(int v=t;v>=;--v)
{
int ci = vjob[i][j].ci;
int gi = vjob[i][j].gi;
if(v >= ci)
{
if(dp[][v-ci] != -)
dp[][v] = max(dp[][v],dp[][v-ci]+gi);
if(dp[][v-ci] != -)
dp[][v] = max(dp[][v],dp[][v-ci]+gi);
}
}
}
}
//最多1
else if(s[i]==)
{
for(int v=t;v>=;--v)
{
for(int j=;j<vjob[i].size();++j)
{
int ci = vjob[i][j].ci;
int gi = vjob[i][j].gi;
if(v >= ci)
{
if(dp[][v-ci] != - && ci != )
{
dp[][v] = max(dp[][v],dp[][v-ci]+gi);
}
else if(ci== && dp[][v] != -)
{
//测试数据中竟然有0分钟这种事情!!!
dp[][v] = max(dp[][v],dp[][v]+gi);
}
}
}
}
}
//随意
else if(s[i]==)
{
for(int j=;j<vjob[i].size();++j)
{
for(int v=t;v>=;--v)
{
int ci = vjob[i][j].ci;
int gi = vjob[i][j].gi;
if(v >= ci)
{
if(dp[][v-ci] != -)
dp[][v] = max(dp[][v],dp[][v-ci]+gi);
}
}
}
}
}
printf("%d\n",dp[][t]);
}
return ;
}

hdu3535题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. 使用系统存储过程来监控SQLServer进程和会话具体解释

     承接上文,本文讲述怎样使用系统存储过程来监控系统. SQLServer相同也提供了一系列系统存储过程用于监控SQLServer,获取当前进程.会话.请求以及锁定的具体信息.本文将演示系统存储过程 ...

  2. 扩展VirtualBox中的centos硬盘大小

    一.克隆文件 我之前安装的时候建的是centos 6.3.可是后来空间不够,没办法,又不想重装centos.由于好多东西要配置,特麻烦,所以先想到了使用resize命令,可是在win8中运行D:\Pr ...

  3. Python图像处理库:PIL中Image,ImageDraw等基本模块介绍

    Python图像处理库:PIL中Image,ImageDraw等基本模块介绍 标签: 图像处理PILPYTHON 2016-08-19 10:58 461人阅读 评论(0) 收藏 举报  分类: 其他 ...

  4. 命令行下mysql的部分操作

    远程链接数据库: mysql –u用户名 [–h主机名或者IP地址] –p密码 (用户名是登录的用 户,主机名或者IP地址为可选项,如果是本地连接则不需要,远程连接需要填写,密码是对应用户的密码.) ...

  5. mysql 常用查询语句记录

    SELECT DISTINCT CONCAT('User: ''',USER,'''@''',HOST,''';') AS QUERY FROM mysql.user; GRANT USAGE ON ...

  6. springmvc的执行流程详解

    1.什么是MVC MVC是Model View Controller的缩写,它是一个设计模式 2.springmvc执行流程详细介绍 第一步:发起请求到前端控制器(DispatcherServlet) ...

  7. 浅析Java开发模式—Model1、Model2和三层

    "解耦"的思想一直是我们倡导的,但在实际项目中怎样去做?这是需要我们去好好思考的.下面以Model1.Model2.三层为切入点,对比下去了解解耦的思想. Model1 使用JSP ...

  8. YTU 2774: Prepare for CET6

    2774: Prepare for CET6 时间限制: 1 Sec  内存限制: 128 MB 提交: 40  解决: 37 题目描述 Hard to force the CET4&6 is ...

  9. YTU 2769: 结构体--成绩统计

    2769: 结构体--成绩统计 时间限制: 1 Sec  内存限制: 128 MB 提交: 1021  解决: 530 题目描述 建立一个简单的学生信息表,包括:姓名.性别.年龄及一门课程的成绩,统计 ...

  10. Android开发常用框架汇总

    作为一名程序猿,好的工具会让你在搬运工的道路上越走越远.以下框架是AC在开发过程中经常会使用到的一些好的框架.列在这里做一个小小的总结,包含但不限于此. 响应式编程 RxJava https://gi ...