LINK


题目大意

给你一棵树,每个节点上有一堆饼干

并且告诉你在每个节点上吃饼干吃一块需要多少时间

然后告诉你经过一条边的时间

总时间是T

两个人轮流进行,一个人向下选择子节点行走或者结束游戏并向上移动吃饼干,另一个人割断一条当前节点到儿子的边或者什么都不做

问第一个人可以吃到的最大的饼干的数量

思路

首先可以把边上的时间在dfs的时候抛掉

然后如果在一个节点上停了下来

我们考虑怎么统计吃的饼干,我们肯定会贪心选择需要时间最少的先吃,这样才能吃到尽量多块

然后用线段树(把单个时间当做下标)维护一下链上的所有信息

然后如果在这个节点不停下来,我们需要递归成子问题

显然第二个人会把往下走dp值最大的一个子树搞掉,所以当前的dp值就是往下走的第二大和停下来的max

在第一个节点特判一下就好了


#include<bits/stdc++.h>

using namespace std;

typedef long long ll;

const ll N = 1e6 + 10; 

struct Node {
ll v, w;
} p[N];
vector<Node> g[N];
ll n, T; #define LD (t << 1)
#define RD (t << 1 | 1) ll val[N << 2], siz[N << 2]; void insert(ll t, ll l, ll r, ll pos, ll cursiz) {
val[t] += pos * cursiz;
siz[t] += cursiz;
if (l == r) return;
ll mid = (l + r) >> 1;
if (pos <= mid) insert(LD, l, mid, pos, cursiz);
else insert(RD, mid + 1, r, pos, cursiz);
} ll query(ll t, ll l, ll r, ll vl) {
if (l == r) return min(siz[t], vl / l);
ll mid = (l + r) >> 1;
if (val[LD] <= vl) return siz[LD] + query(RD, mid + 1, r, vl - val[LD]);
else return query(LD, l, mid, vl);
} ll dfs(ll u, ll lef) {
insert(1, 1, 1e6, p[u].w, p[u].v);
ll res = query(1, 1, 1e6, lef);
ll f1 = 0, f2 = 0;
for (auto now : g[u]) {
ll v = now.v;
if (lef <= now.w * 2) continue;
ll cur = dfs(v, lef - now.w * 2);
if (cur > f1) f2 = f1, f1 = cur;
else if (cur > f2) f2 = cur;
}
insert(1, 1, 1e6, p[u].w, -p[u].v);
if (u == 1) return max(res, f1);
else return max(res, f2);
} int main() {
scanf("%lld %lld", &n, &T);
for (ll i = 1; i <= n; i++) scanf("%lld", &p[i].v);
for (ll i = 1; i <= n; i++) scanf("%lld", &p[i].w);
for (ll i = 2; i <= n; i++) {
ll u, w; scanf("%lld %lld", &u, &w);
g[u].push_back((Node) {i, w});
}
printf("%lld", dfs(1, T));
return 0;
}

Codeforces1099F. Cookies【DP】【线段树】【贪心】【博弈】【沙比提(这是啥算法)】的更多相关文章

  1. Codeforces1099F. Cookies(线段树+dp+贪心+博弈)

    题目链接:传送门 思路: 分析到处理节点时的吃cookie的顺序了,然鹅不会用线段树维护前缀和.技术门槛QAQ... 很容易想到可以从root开始搜索,每次深入消耗时间2*边权w. 然后对于深入到点u ...

  2. ZOJ 3349 Special Subsequence 简单DP + 线段树

    同 HDU 2836 只不过改成了求最长子串. DP+线段树单点修改+区间查最值. #include <cstdio> #include <cstring> #include ...

  3. hdu 3016 dp+线段树

    Man Down Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  4. BZOJ_1826_[JSOI2010]缓存交换 _线段树+贪心

    BZOJ_1826_[JSOI2010]缓存交换 _线段树+贪心 Description 在计算机中,CPU只能和高速缓存Cache直接交换数据.当所需的内存单元不在Cache中时,则需要从主存里把数 ...

  5. Bzoj5251 线段树+贪心

    Bzoj5251 线段树+贪心 记录本蒟蒻省选后的第一篇题解!国际惯例的题面:首先这个东西显然是一棵树.如果我们把数值排序,并建立这棵树的dfs序,显然dfs序上的一个区间对应数值的一个区间,且根为数 ...

  6. 2018.10.20 NOIP模拟 蛋糕(线段树+贪心/lis)

    传送门 听说是最长反链衍生出的对偶定理就能秒了. 本蒟蒻直接用线段树模拟维护的. 对于第一维排序. 维护第二维的偏序关系可以借助线段树/树状数组维护逆序对的思想建立权值线段树贪心求解. 代码

  7. cf834D(dp+线段树区间最值,区间更新)

    题目链接: http://codeforces.com/contest/834/problem/D 题意: 每个数字代表一种颜色, 一个区间的美丽度为其中颜色的种数, 给出一个有 n 个元素的数组, ...

  8. Codeforces Round #620 F2. Animal Observation (hard version) (dp + 线段树)

    Codeforces Round #620 F2. Animal Observation (hard version) (dp + 线段树) 题目链接 题意 给定一个nm的矩阵,每行取2k的矩阵,求总 ...

  9. BZOJ 1852 [MexicoOI06]最长不下降序列(贪心+DP+线段树+离散化)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1852 [题目大意] 给你N对数A1,B1……An,Bn.要求你从中找出最多的对, 把它 ...

  10. [USACO2005][POJ3171]Cleaning Shifts(DP+线段树优化)

    题目:http://poj.org/problem?id=3171 题意:给你n个区间[a,b],每个区间都有一个费用c,要你用最小的费用覆盖区间[M,E] 分析:经典的区间覆盖问题,百度可以搜到这个 ...

随机推荐

  1. opencv学习之路(22)、轮廓查找与绘制(一)

    一.简介 图2 二.代码 #include"opencv2/opencv.hpp" #include<iostream> using namespace std; us ...

  2. Codeforces 438E The Child and Binary Tree - 生成函数 - 多项式

    题目传送门 传送点I 传送点II 传送点III 题目大意 每个点的权值$c\in {c_{1}, c_{2}, \cdots, c_{n}}$,问对于每个$1\leqslant s\leqslant ...

  3. spring boot2+jpa+thymeleaf增删改查例子

    参考这遍文章做了一个例子,稍微不同之处,原文是spring boot.mysql,这里改成了spring boot 2.Oracle. 一.pom.xml引入相关模块web.jpa.thymeleaf ...

  4. 记 Java 各版本新特性

    Java 8: Lambda 表达式: (paramList) -> expression; 或者 (paramList) -> {statments;} 演示用例: public int ...

  5. 【IOS】#import和#include有什么区别,@class呢,#import<>跟#import ""有什么区别?

    1.#import是object-c导入头文件的关键字,#include是C/c++导入头文件的关键字,使用#import导入头文件会自动只导入一次,不会重复导入. 2.@class是告诉编译器某个类 ...

  6. Rancher2.0中邮件通知的设置

    1-邮件通知的设置-中国电信189邮箱 2-2-邮件通知的设置-腾讯免费企业邮箱 **说明:网易163邮箱.QQ邮箱没有设置成功,可能是因为邮箱设置得太安全的缘故.   参考链接: 中国电信189邮箱 ...

  7. 力扣(LeetCode) 821. 字符的最短距离

    给定一个字符串 S 和一个字符 C.返回一个代表字符串 S 中每个字符到字符串 S 中的字符 C 的最短距离的数组. 示例 1: 输入: S = "loveleetcode", C ...

  8. SQL Update 语句详解

    SQL Update 语句详解   Update 语句 Update 语句用于修改表中的数据. 语法: UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值 Person: L ...

  9. day050 django第一天 自定义框架

    1.简单的web框架 1. 创建一个简单的python文件: import socket sever=socket.socket() sever.bind(('127.0.0.1',8001)) se ...

  10. leetcode python 007

    ##  翻转整数def evert(int0):    if int0<0:        flg=1    else:        flg=0    e=int(str(int0)[flg: ...