hdu 3033 I love sneakers! 分组背包
I love sneakers!
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
There are several brands of sneakers that Iserlohn wants to collect, such as Air Jordan and Nike Pro. And each brand has released various products. For the reason that Iserlohn is definitely a sneaker-mania, he desires to buy at least one product for each brand.
Although the fixed price of each product has been labeled, Iserlohn sets values for each of them based on his own tendency. With handsome but limited money, he wants to maximize the total value of the shoes he is going to buy. Obviously, as a collector, he won’t buy the same product twice.
Now, Iserlohn needs you to help him find the best solution of his problem, which means to maximize the total value of the products he can buy.
1 4 6
2 5 7
3 4 99
1 55 77
2 44 66
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define pi (4*atan(1.0))
#define eps 1e-14
const int N=1e4+,M=4e6+,inf=1e9+,mod=1e9+;
const ll INF=1e18+;
int dp[][N];
int v[][N],w[][N];
int si[];
int main()
{
int n,T,k;
while(~scanf("%d%d%d",&n,&T,&k))
{
memset(si,,sizeof(si));
memset(dp[],,sizeof(dp[]));
for(int i=;i<=n;i++)
{
int flag;
scanf("%d",&flag);
scanf("%d%d",&v[flag][si[flag]],&w[flag][si[flag]]);
si[flag]++;
}
for(int i=;i<=k;i++)
{
for(int t=;t<=T;t++)
dp[i][t]=-inf;
for(int t=;t<si[i];t++)
{
for(int j=T;j>=v[i][t];j--)
{
dp[i][j]=max(dp[i][j],dp[i][j-v[i][t]]+w[i][t]);
dp[i][j]=max(dp[i][j],dp[i-][j-v[i][t]]+w[i][t]);
}
}
}
if(dp[k][T]>=)
printf("%d\n",dp[k][T]);
else
printf("Impossible\n");
}
return ;
}
hdu 3033 I love sneakers! 分组背包的更多相关文章
- hdu 3033 I love sneakers!(分组背包+每组至少选一个)
		
I love sneakers! Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
 - HDU 3033 I love sneakers! 我爱运动鞋 (分组背包+01背包,变形)
		
题意: 有n<=100双鞋子,分别属于一个牌子,共k<=10个牌子.现有m<=10000钱,问每个牌子至少挑1双,能获得的最大价值是多少? 思路: 分组背包的变形,变成了相反的,每组 ...
 - HDU3033I love sneakers!(分组背包)
		
http://acm.hdu.edu.cn/showproblem.php?pid=3033 本题的意思就是说现在有n种牌子的鞋子,每种品牌有一些不同的鞋,每双鞋子都有一个特定的权值,现在要求每种品牌 ...
 - I love sneakers!(分组背包HDU3033)
		
I love sneakers! Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
 - hdu3033 I love sneakers!        分组背包变形
		
分组背包要求每一组里面只能选一个,这个题目要求每一组里面至少选一个物品. dp[i, j] 表示前 i 组里面在每组至少放进一个物品的情况下,当花费 j 的时候,所得到的的最大价值.这个状态可以由三个 ...
 - HDU 4341 Gold miner (分组背包)
		
先把线按照距离原点的距离排序,然后用叉积把在同一条直线上的点放在一起, 把在同一条线上的点中的前i个点当成一个点就转化成了分组背包. 写if(kas++) putchar('\n') 居然PE了,PE ...
 - HDU 4341 Gold miner(分组背包)
		
题目链接 Gold miner 目标是要在规定时间内获得的价值总和要尽可能大. 我们先用并查集把斜率相同的物品分在同一个组. 这些组里的物品按照y坐标的大小升序排序. 如果组内的一个物品被选取了,那该 ...
 - hdu3033 I love sneakers! 分组背包变形(详解)
		
这个题很怪,一开始没仔细读题,写了个简单的分组背包交上去,果不其然WA. 题目分析: 分组背包问题是这样描述的:有K组物品,每组 i 个,费用分别为Ci ,价值为Vi,每组物品是互斥的,只能取一个或者 ...
 - [HDU 3033] I love sneakers! (动态规划分组背包)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3033 题意:给你K种品牌,每种品牌有不同种鞋,现在每种品牌至少挑一款鞋,问获得的最大价值,如果不能每种 ...
 
随机推荐
- ubuntu apache开启重写模块
			
http://www.iblue.cc/2011/09/ubuntu-apache%E5%BC%80%E5%90%AF%E9%87%8D%E5%86%99%E6%A8%A1%E5%9D%97/ Ubu ...
 - linux配置java环境变量(详细)【转】
			
转自:http://www.cnblogs.com/samcn/archive/2011/03/16/1986248.html 一. 解压安装jdk 在shell终端下进入jdk-6u14-linux ...
 - Wall Street English
			
1月23号,报名Wall Street English!
 - PHP中header函数的用法及其注意重点是什么呢
			
1.使用header函数进行跳转页面: header('Location:'.$url); 其中$url就是将要跳转的url了. 这种用法的注意事项有以下几点: •Location和":&q ...
 - 11、Jsp加强/EL表达式/jsp标签
			
1 Jsp基础回顾 Jsp基础 1)Jsp的执行过程 tomcat服务器完成:jsp文件->翻译成java文件->编译成class字节码文件-> 构造类对象-> 调用方法 to ...
 - C#Winform常引用的库
			
1.DevExpress:引用其下的不同DLL,可操作使用不同的控件 2.IrisSkin2:引用对应的DLL后,代码如下 private Sunisoft.IrisSkin.SkinEngine s ...
 - JavaScript DOM 编程艺术(第2版)读书笔记(2)
			
JavaScript 语法 注释 单行注释:// 多行注释:/* */ "<!--"可以用作单行注释,由于和HTML的"<!-- -->"多 ...
 - SQL数据类型大全 《转自网络》
			
数据类型是数据的一种属性,表示数据所表示信息的类型.任何一种计算机语言都定义了自己的数据类型.当然,不同的程序语言都具有不同的特点,所定义的数据类型的种类和名称都或多或少有些不同.SQLServer ...
 - C#微信开发文档
			
C#微信开发文档 开发前准备 微信公众平台链接: https://mp.weixin.qq.com/cgi-bin/home?t=home/index&lang=zh_CN 开发初期我们使用测 ...
 - linux里用cmake安装的软件要怎么卸载?
			
找到make install之后产生的这个文件install_manifest.txt 这里在build文件里面有一个 install_manifest.txt,在里面有安装的所有东西的路径,删除它们 ...