hdu3535 背包大杂汇

时间:2021-02-07 04:09:08

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

//不想写题解,这道题让我对背包的理解更深了,我相信我不会忘记的。。。。

代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
const int INF=0x3f3f3f3f; int dp[][];
int t[],g[]; int main()
{
int N,T;
while(scanf("%d%d",&N,&T)==)
{
memset(dp,,sizeof(dp));
for(int i=; i<=N; i++)
{
int n,s;
scanf("%d%d",&n,&s);
for(int k=; k<=n; k++)
scanf("%d%d",&t[k],&g[k]);
if(s==) ///至少选一件
{
for(int j=; j<=T; j++)
dp[i][j]=-INF;
for(int j=; j<=n; j++)
for(int k=T; k>=t[j]; k--)
dp[i][k]=max(dp[i][k],max(dp[i][k-t[j]]+g[j],dp[i-][k-t[j]]+g[j]));
}
else if(s==) ///最多选一件
{
for(int j=; j<=T; j++)
dp[i][j]=dp[i-][j];
for(int j=; j<=n; j++)
for(int k=T; k>=t[j]; k--)
dp[i][k]=max(dp[i][k],dp[i-][k-t[j]]+g[j]);
}
else ///随便选
{
for(int j=; j<=T; j++)
dp[i][j]=dp[i-][j];
for(int j=; j<=n; j++)
for(int k=T; k>=t[j]; k--)
dp[i][k]=max(dp[i][k],max(dp[i-][k-t[j]]+g[j],dp[i][k-t[j]]+g[j]));
}
}
if(dp[N][T]<=) dp[N][T]=-;
printf("%d\n",dp[N][T]);
}
return ;
}

hdu3535 背包大杂汇的更多相关文章

  1. jQuery知识大杂汇

    1.jQuery 语法是通过选取 HTML 元素,并对选取的元素执行某些操作. 基础语法: $(selector).action() 举几枚栗子吧: $(this).hide() - 隐藏当前元素 $ ...

  2. &lbrack;整理&rsqb;qbxt集训10场考试 大 杂 烩 (前篇)

    Contest 1 A 计算 \(n!\mod 2^{32}\) .发现数一大答案就为 \(0\) ,直接输出即可. B 一个 \(n\times m\) 的网格,网格中的数都在 \([1,nm]\) ...

  3. &lbrack;整理&rsqb;qbxt集训10场考试 大 杂 烩 (后篇)

    前篇 Contest 6 A 两个数,第 \(i\) 轮从较大数(如果相等就是第一个)里减去 \(i\) ,问操作不能进行时两数分别为多少. 首先把大数减到和小数差不多,然后我们会发现接下来两数会轮流 ...

  4. HDU 5754 Life Winner Bo(各类博弈大杂合)

    http://acm.hdu.edu.cn/showproblem.php?pid=5754 题意: 给一个国际象棋的棋盘,起点为(1,1),终点为(n,m),现在每个棋子只能往右下方走,并且有4种不 ...

  5. python大杂铺

      python中continue,break,return三者之间的区别 return 会直接令函数返回,所有该函数体内的代码都不再执行了,所以该函数体内的循环也不可能再继续运行. break:跳出 ...

  6. hdu&ndash&semi;2369 Bone Collector II&lpar;01背包变形题&rpar;

    题意:求解01背包价值的第K优解. 分析: 基本思想是将每个状态都表示成有序队列,将状态转移方程中的max/min转化成有序队列的合并. 首先看01背包求最优解的状态转移方程:\[dp\left[ j ...

  7. 关于01背包求第k优解

    引用:http://szy961124.blog.163.com/blog/static/132346674201092775320970/ 求次优解.第K优解 对于求次优解.第K优解类的问题,如果相 ...

  8. HDU 2639 骨头收集者 II【01背包 】&plus;【第K优决策】

    题目链接:https://vjudge.net/contest/103424#problem/H 题目大意:与01背包模板题类似,只不过要我们求第K个最大的总价值. 解题分析: 其基本思想是将每个状态 ...

  9. HDU 1059 Dividing 分配(多重背包,母函数)

    题意: 两个人共同收藏了一些石头,现在要分道扬镳,得分资产了,石头具有不同的收藏价值,分别为1.2.3.4.5.6共6个价钱.问:是否能公平分配? 输入: 每行为一个测试例子,每行包括6个数字,分别对 ...

随机推荐

  1. 从题目中学习java语法

    一.输入输出 1.输入圆的半径,计算并输出圆的周长和面积: import java.util.Scanner; public class zuoye01_circle { public static ...

  2. 淘宝&lpar;阿里百川&rpar;手机客户端开发日记第六篇 Service详解&lpar;一&rpar;

    public abstract class Service; [API文档关于Service类的介绍] A Service is an application component representi ...

  3. BarTender破解问题

    要使用BarTender 10.0的.net组件打印条码,就必须使用企业版的.在破解说明中会指出,BarTender破解过程要断开internet连接.在企业应用开发中,可能会遇到在局域网中给多个机器 ...

  4. XML文件序列化和反序列化的相关内容

    问题缘由: XML反序列化出错,XML 文档(2, 2)中有错误,不应有 <configuration xmlns=''> 解决方法: 其实这个是很简单的,因为一般来说都是XML文档书写错 ...

  5. PullToRefreshListView调用onRefreshComplete方法 无法取消刷新的bug

    我们在使用框架:   PullToRefreshListView 实现下拉或者上拉加载时候,可能在上拉 完成时候,调用onRefreshComplete方法去 停止 刷新操作,但是,可能无效,测试产生 ...

  6. &lbrack;转&rsqb;jQuery插件开发精品教程,让你的jQuery提升一个台阶

    原文链接:http://www.cnblogs.com/Wayou/p/jquery_plugin_tutorial.html 要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其 ...

  7. selenium C&num;下的zencart自动化测试(WFloginUrlPayment)环境4&period;0

    using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using Sy ...

  8. Kafka水位&lpar;high watermark&rpar;与leader epoch的讨论

    ~~~这是一篇有点长的文章,希望不会令你昏昏欲睡~~~ 本文主要讨论0.11版本之前Kafka的副本备份机制的设计问题以及0.11是如何解决的.简单来说,0.11之前副本备份机制主要依赖水位(或水印) ...

  9. npm install安装时忘记--save解决方法

    title: npm install安装时忘记--save解决方法 date: 2017-05-07 20:17:54 tags: npm categories: --- 网上还有一个解决方案就是: ...

  10. 封装一个使用cURL以POST方式请求https协议的公众方法

    打开php7.2手册,搜索curl function getRequest($url,$type='get', $data = [], $timeout = 10) (需要更改){ $ssl = st ...