CF1099F Cookies
题目地址:CF1099F Cookies
树形dp套树形数据结构
对每个节点 \(i\) ,分两步进行:
1.令 \(f_i\) 为Mitya在节点 \(i\) 停止游戏最多可以吃到多少块饼干
我们可以进行一次dfs,用一个树形数据结构(树状数组、线段树、平衡树)来维护从树根节点 \(1\) 到节点 \(i\) 经过的路径上所有节点的“属性二元组”—— \((t_i,x_i)\) ,为了吃到更多块饼干,应该尽量吃 \(t_i\) 小的饼干。
以树状数组为例。由于 \(1≤t_i≤10^6\) ,直接在值域上建立两个树状数组(当然可以先用 \(O(n\ log\ n)\) 的时间离散化,不过此题不必要),一个记录时间 \(ct\) ,一个记录个数 \(cx\) 。dfs到节点 \(i\) 时,首先执行add操作,在 \(ct\) 的位置 \(t_i\) 上加 \(t_ix_i\) ,同时在 \(cx\) 的位置 \(t_i\) 上加 \(x_i\) 。在 \(ct\) 上二分查找 \(ask_{ct}(k)≤T-2S\) 的最大值,其中 \(S\) 为从树根节点 \(1\) 到节点 \(i\) 所需的时间,一来一回所以需要两倍的 \(S\) 。那么 \(f_i\) 的值为在 \(cx\) 上 \(ask_{cx}(k)\) 与剩下时间 \(T-2S-ask_{ct}(k)\) 除以后一个吃单块饼干的时间 \(k+1\) 向下取整后的值之和(当然若 \(k=m\) 则不需要加上后面的部分)。dfs回溯的时候进行类似操作即可。
2.考虑Vasya的干扰,由于Vasya可以删除节点 \(i\) 与 \(i\) 的子节点之间的边,为了删除的有意义,就必须要删掉节点 \(i\) 的所有子节点中结果最大的节点。
因此,令 \(m1_i,m2_i\) 分别为在以节点 \(i\) 为根的子树中除节点 \(i\) 自己外结果的最大值和非严格次大值,特别的,若不存在次大值, \(m2_i=0\)
令 \(dp_i\) 为按照游戏规则在以节点 \(i\) 为根的子树中,Mitya在某一个节点停止游戏可以吃到的饼干数的最大值
显然,若节点 \(i\) 为根节点 \(1\) ,由于Mitya先进行操作,因此 \(dp_i=max(f_i,m1_i)\)
否则,\(dp_i=max(f_i,m2_i)\)
\(dp_1\) 即为所求
时间复杂度 \(O(n\ log^2\ maxT)\)
代码:
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int N = 100006, M = 1000006;
ll n, m, T, x[N], t[N], f[N], ct[M], cx[M], m1[N], m2[N], dp[N];
vector<pair<int, ll> > e[N];
void addct(int a, ll k) {
while (a <= m) {
ct[a] += k;
a += a & -a;
}
}
ll askct(int a) {
ll ans = 0;
while (a) {
ans += ct[a];
a -= a & -a;
}
return ans;
}
void addcx(int a, ll k) {
while (a <= m) {
cx[a] += k;
a += a & -a;
}
}
ll askcx(int a) {
ll ans = 0;
while (a) {
ans += cx[a];
a -= a & -a;
}
return ans;
}
void dfs(int a, ll S) {
addct(t[a], t[a] * x[a]);
addcx(t[a], x[a]);
int l = 1, r = m + 1;
while (l < r) {
int mid = (l + r) >> 1;
if (askct(mid) <= T - (S << 1)) l = mid + 1;
else r = mid;
}
int k = l - 1;
f[a] = askcx(k);
if (k != m) f[a] += (T - (S << 1) - askct(k)) / (k + 1);
for (unsigned int i = 0; i < e[a].size(); i++)
dfs(e[a][i].first, S + e[a][i].second);
addct(t[a], -t[a] * x[a]);
addcx(t[a], -x[a]);
}
void dfs(int a) {
for (unsigned int i = 0; i < e[a].size(); i++) {
int y = e[a][i].first;
dfs(y);
if (dp[y] >= m1[a]) {
m2[a] = m1[a];
m1[a] = dp[y];
} else if (dp[y] >= m2[a]) m2[a] = dp[y];
}
if (a == 1) dp[a] = max(f[a], m1[a]);
else dp[a] = max(f[a], m2[a]);
}
int main() {
cin >> n >> T;
for (int i = 1; i <= n; i++) scanf("%lld", &x[i]);
for (int i = 1; i <= n; i++) {
scanf("%lld", &t[i]);
m = max(m, t[i]);
}
for (int i = 2; i <= n; i++) {
int p;
ll l;
scanf("%d %lld", &p, &l);
e[p].push_back(make_pair(i, l));
}
dfs(1, 0);
dfs(1);
cout << dp[1] << endl;
return 0;
}
CF1099F Cookies的更多相关文章
- scrapy cookies:将cookies保存到文件以及从文件加载cookies
我在使用scrapy模拟登录新浪微博时,想将登录成功后的cookies保存到本地,下次加载它实现直接登录,省去中间一系列的请求和POST等.关于如何从本次请求中获取并在下次请求中附带上cookies的 ...
- ASP.Net MVC Session和Cookies的简单使用
目标:用Session和Cookies实现登陆信息保存和展现 Cookies实现: Controller: //把登陆用户名存到cookies中 HttpCookie cook = new HttpC ...
- Webform(六)——登录状态保持(Cookies内置对象)
用户用浏览器访问一个网站,由于采用的http的特性,Web服务器并不能知道是哪一个用户正在访问,但一些网站,希望能够知道访问者的一些信息,例如是不是第一次访问,访问者上次访问时是否有未做完的工作,这次 ...
- [LeetCode] Assign Cookies 分点心
Assume you are an awesome parent and want to give your children some cookies. But, you should give e ...
- jquery缓存使用jquery.cookies.2.2.0.min.js
$.cookies.set(key, obj, { hoursToLive: 2}); key标识的键 , obj存入的值可以缓存json对象, hoursToLive 缓存小时数 $.cookies ...
- C# HttpWebRequest获取COOKIES
C# HttpWebRequest获取COOKIES byte[] bytes = Encoding.Default.GetBytes(_post); CookieContainer myCookie ...
- HTML5-本地存储与cookies
一.H5的几种存储形式 1.本地存储(localstorage和sessionstorage) 存储形式:key-->value 过期策略:localstorage永久存储,不过期,除非手动删除 ...
- scrapy加载cookies登陆
import scrapy from xxxx.items import XXXXItem from scrapy.http.request import Request class ZndsSpid ...
- ASP.NET知识总结(9.使用Cookies实现购物车)
ListInfo.aspx向购物车的添加商品的方法 private void GouWu(string name, double price, string id) { //往购物车中添加商品 Htt ...
随机推荐
- Ajax结合Json进行交互数据(四)
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...
- [ZJOI2007]棋盘制作 悬线法dp 求限制下的最大子矩阵
https://www.luogu.org/problemnew/show/P1169 第一次听说到这种dp的名称叫做悬线法,听起来好厉害 题意是求一个矩阵内的最大01交错子矩阵,开始想的是dp[20 ...
- Java集合、Iterator迭代器和增强for循环整理
集合 集合,集合是java中提供的一种容器,可以用来存储多个数据. 数组的长度是固定的.集合的长度是可变的.集合中存储的元素必须是引用类型数据 1.1 ArrayList集合存储元素 pac ...
- 为SNP增加种族人群频率
一.Ensemble:http://www.ensembl.info/2015/06/18/1000-genomes-phase-3-frequencies-genotypes-and-ld-data ...
- CentOS 安装Python3、pip3
https://ehlxr.me/2017/01/07/CentOS-7-%E5%AE%89%E8%A3%85-Python3%E3%80%81pip3/ CentOS 7 默认安装了 Python ...
- java.lang.UnsatisfiedLinkError: org.apache.hadoop.io.nativeio.NativeIO$Windows.access0(Ljava/lang/String;I)Z
在 windows 上运行 MapReduce 时报如下异常 Exception in thread "main" java.lang.UnsatisfiedLinkError: ...
- CSS3 vmax的用法
1. calc() calc():在流体布局上,可以通过calc()计算得到元素的宽度. 2. vw/vh/vmin/vmax的使用 vw/vh/vmin/vmax是视窗单位,也是相对单位.相对的不是 ...
- 阿里RocketMq(TCP模式)
针对公司业务逻辑,向阿里云MQ发送指定数据,消费端根据数据来做具体的业务,分两个项目,一个生产端(Producer).一个消费端(Consumer) 生产端通过定时任务执行sql向阿里云MQ发送数据, ...
- SonarQube(代码质量管理)配置与使用
继 Sonarqube(代码质量管理)环境搭建,交大家如何配置与使用Sonarqube 1: 汉化Sonarqube: 找到 Setting --> Update Center --> A ...
- sublime text3支持Vue文件高亮显示
sublime text 默认打开.vue文件全部都是白色的,不是特别方便.安装插件可以做到代码高亮显示 1.插件vue-syntax-highlight 下载地址:github https://gi ...