816E. Karen and Supermarket 树形DP
题意:给出n个商品,除第一个商品外,所有商品可以选择使用优惠券,但要求其前驱商品已被购买,问消费k以下能买几个不同的商品
思路:题意很明显就是树形DP。对于一个商品有三种选择,买且使用优惠券,买不使用优惠券,不买。当然如果直接暴力进行转移是$O(n^3)$的,但我们可以统计每个结点其子节点的个数sz,sz~0地来遍历,这样就可以将某节点与其父节点进行转移,从而避免了多余无效的转移,优化到$O(n^2)$。dp[k][i][j]代表 k是否不使用优惠券,以i为父节点 购买j个商品的最小花费。
/** @Date : 2017-07-01 15:38:39
* @FileName: 816E 树形DP.cpp
* @Platform: Windows
* @Author : Lweleth (SoungEarlf@gmail.com)
* @Link : https://github.com/
* @Version : $Id$
*/
#include <bits/stdc++.h>
#define LL long long
#define PII pair
#define MP(x, y) make_pair((x),(y))
#define fi first
#define se second
#define PB(x) push_back((x))
#define MMG(x) memset((x), -1,sizeof(x))
#define MMF(x) memset((x),0,sizeof(x))
#define MMI(x) memset((x), INF, sizeof(x))
using namespace std; const LL INF = 0x3f3f3f3f;
const int N = 1e5+20;
const double eps = 1e-8; LL n, m;
LL c[N], b[N];
LL dp[2][5010][5010];
int sz[5010];
vector edg[5010]; int dfs(int x, int pre)
{
sz[x] = 1;
dp[1][x][0] = 0;
dp[1][x][1] = c[x];//不用优惠券
dp[0][x][1] = c[x] - b[x];//用优惠券
for(auto np:edg[x])
{
if(np == pre)
continue;
dfs(np, x);
for(int i = sz[x]; i >= 0; i--)//
{
for(int j = sz[np]; j >= 0; j--)
{
dp[0][x][i + j] = min(dp[0][x][i + j], dp[0][x][i] + min(dp[1][np][j], dp[0][np][j]));
dp[1][x][i + j] = min(dp[1][x][i + j], dp[1][x][i] + dp[1][np][j]);
}
}
sz[x] += sz[np];
}
}
int main()
{
while(cin >> n >> m)
{
MMF(sz);
MMI(dp);
int t;
scanf("%lld%lld", c + 1, b + 1);
for(int i = 2; i <= n; i++)
{
scanf("%lld%lld%d", c + i, b + i, &t);
edg[t].PB(i);
}
dfs(1, -1);
for(int i = n; i >= 0; i--)
{
LL mi = min(dp[1][1][i], dp[0][1][i]);
if(mi <= m)
{
printf("%d\n", i);
break;
}
}
}
return 0;
}
816E. Karen and Supermarket 树形DP的更多相关文章
- Codeforces 815C Karen and Supermarket 树形dp
		
Karen and Supermarket 感觉就是很普通的树形dp. dp[ i ][ 0 ][ u ]表示在 i 这棵子树中选择 u 个且 i 不用优惠券的最小花费. dp[ i ][ 1 ][ ...
 - CF815C Karen and Supermarket [树形DP]
		
题目传送门 Karen and Supermarket On the way home, Karen decided to stop by the supermarket to buy some gr ...
 - Codeforces Round #419 (Div. 1) C. Karen and Supermarket 树形DP
		
C. Karen and Supermarket On the way home, Karen decided to stop by the supermarket to buy some g ...
 - CodeForces 816E Karen and Supermarket  ——(树形DP)
		
题意:有n件商品,每件商品都最多只能被买一次,且有一个原价和一个如果使用优惠券以后可以减少的价格,同时,除了第一件商品以外每件商品都有一个xi属性,表示买这个商品时如果要使用优惠券必须已经使用了xi的 ...
 - [CF816E] Karen and Supermarket1 [树形dp]
		
传送门 - > \(CF816E\) Karen and Supermarket 题意翻译 在回家的路上,凯伦决定到超市停下来买一些杂货. 她需要买很多东西,但因为她是学生,所以她的预算仍然很有 ...
 - cf 816E Karen and Supermarket
		
题目大意 给定\(n\)一颗树,每个点上有一个物品 每个物品有价格\(c[i]\) 有优惠券,能使价格减少\(d[i]\) 但是使用优惠券的前提时购买该物品,且父亲也使用优惠券 给定钱包余额\(lim ...
 - Codeforces Round #419 (Div. 2) E. Karen and Supermarket(树形dp)
		
http://codeforces.com/contest/816/problem/E 题意: 去超市买东西,共有m块钱,每件商品有优惠卷可用,前提是xi商品的优惠券被用.问最多能买多少件商品? 思路 ...
 - codeforces 816 E. Karen and Supermarket(树形dp)
		
题目链接:http://codeforces.com/contest/816/problem/E 题意:有n件商品,每件有价格ci,优惠券di,对于i>=2,使用di的条件为:xi的优惠券需要被 ...
 - E. Karen and Supermarket
		
E. Karen and Supermarket time limit per test 2 seconds memory limit per test 512 megabytes input sta ...
 
随机推荐
- Java 学习笔记 ------第四章 认识对象
			
本章学习目标: 区分基本类型与类类型 了解对象与参考的关系 从打包器认识对象 以对象观点看待数组 认识字符串的特性 一."=" 和 "==" 当=用于基本类型时 ...
 - 2018-2019-20172321 《Java软件结构与数据结构》第五周学习总结
			
2018-2019-20172321 <Java软件结构与数据结构>第五周学习总结 教材学习内容总结 第9章 排序与查找 9.1查找 查找是这样一个过程,即在某个项目组中寻找某一指定目标元 ...
 - 简评搜狗输入法(ios端)
			
首先说说为什么不使用iPhone自带的输入法呢,首先是词库不够丰富,好多简单的词语需要逐个字逐个字的选择,记忆功能不太好,其次是全键盘式的输入我不太习惯,还是九宫格的输入法比较简单,更方便快捷. 搜狗 ...
 - Programming Protocol-Independent Packet Processors
			
引言 OpenFlow协议固定的包头域数目,使得南向协议过于死板. P4可以实现自定义包头,增加灵活性. P4是OpenFlow未来发展的方向. We propose P4 as a strawman ...
 - OOP 1.2 const关键字
			
1.2 const关键字 1.常量 指针常量 定义常量:const 类型 =值 定义指针常量:const *类型=值 常量指针不可通过常量指针修改其指向的内容 可直接修改其指向的内容 常量指针的指向可 ...
 - 团队作业4——第一次项目冲刺(Alpha版本)第一次
			
一.会议内容 制定任务内容 制作leangoo表格 初步工作 二.各人工作 成员 计划任务 遇见难题 贡献比 塗家瑜(组长) 后端与数据库通讯 无 1 张新磊 表设计 无 1 姚燕彬 测试计划编写 无 ...
 - jenkin重新注册用户
			
http://www.cnblogs.com/xiao-fy/
 - Java 调用 google 翻译
			
1.Java代码 public class Translator { public String translate(String langFrom, String langTo, String wo ...
 - LoadRunner脚本增强技巧之手动关联
			
个人认为LoadRunner的手动关联技巧可以看做参数化的一种,区别在与获取参数的来源不同. 一般的参数化:把脚本中一个写死的数值或者字符串用一个变量参数来代替,每次迭代的时候,从本地文件或者数据库中 ...
 - SQL中的逻辑运算符
			
逻辑运算符和比较运算符一样,都是返回 true 或 false 值得布尔数据类型. 运算符 行为 ALL 如果一个比较集中全部都是 true ,则值为 true AND 如果两个布尔值表达式均为 ...