bzoj3011 可并堆
我们可以遍历得出每个节点到根节点的距离h,然后用可并堆进行维护。树形dp
我用的是pairing heap
#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std ; struct node {
long long value ;
node * brother ;
node * child ;
node ( const long long value ) : value ( value ) ,
brother ( ) , child ( ) {} ;
} ; node * merge ( node * a , node * b ) {
if ( a == ) return b ;
if ( b == ) return a ;
if ( a -> value < b -> value ) swap ( a , b ) ;
b -> brother = a -> child ;
a -> child = b ;
a -> brother = ;
return a ;
} node * pop ( node * a ) {
node * o = a -> child ;
delete a ;
if ( o == ) return ;
static queue < node * > q ;
while ( ! q . empty () ) q . pop () ;
while ( o ) {
q . push ( o ) ;
o = o -> brother ;
}
while ( q . size () > 1u ) {
node * a = q . front () ;
q . pop () ;
node * b = q . front () ;
q . pop () ;
q . push ( merge ( a , b ) ) ;
}
return q . front () ;
} const int MAXN = + ;
int pa [ MAXN ] ;
long long l [ MAXN ] ;
long long h [ MAXN ] ;
int size [ MAXN ] ;
int N ;
long long L ;
node * heap [ MAXN ] ; int main () {
scanf ( "%d%lld" , & N , & L ) ;
for ( int i = ; i <= N ; ++ i )
scanf ( "%d%lld" , & pa [ i ] , & l [ i ] ) ;
for ( int i = ; i <= N ; ++ i ) h [ i ] = l [ i ] + h [ pa [ i ] ] ;
for ( int i = ; i <= N ; ++ i ) {
heap [ i ] = new node ( h [ i ] ) ;
size [ i ] = ;
}
for ( int i = N ; i >= ; -- i ) {
while ( heap [ i ] -> value - h [ i ] > L ) {
heap [ i ] = pop ( heap [ i ] ) ;
size [ i ] -- ;
}
heap [ pa [ i ] ] = merge ( heap [ pa [ i ] ] , heap [ i ] ) ;
size [ pa [ i ] ] += size [ i ] ;
}
while ( heap [ ] -> value - h [ ] > L ) {
heap [ ] = pop ( heap [ ] ) ;
size [ ] -- ;
}
for ( int i = ; i <= N ; ++ i )
printf ( "%d\n" , size [ i ] ) ;
return ;
}
bzoj3011 可并堆的更多相关文章
- 【BZOJ3011】[Usaco2012 Dec]Running Away From the Barn 可并堆
[BZOJ3011][Usaco2012 Dec]Running Away From the Barn Description It's milking time at Farmer John's f ...
- Java 堆内存与栈内存异同(Java Heap Memory vs Stack Memory Difference)
--reference Java Heap Memory vs Stack Memory Difference 在数据结构中,堆和栈可以说是两种最基础的数据结构,而Java中的栈内存空间和堆内存空间有 ...
- [数据结构]——堆(Heap)、堆排序和TopK
堆(heap),是一种特殊的数据结构.之所以特殊,因为堆的形象化是一个棵完全二叉树,并且满足任意节点始终不大于(或者不小于)左右子节点(有别于二叉搜索树Binary Search Tree).其中,前 ...
- 《徐徐道来话Java》:PriorityQueue和最小堆
在讲解PriorityQueue之前,需要先熟悉一个有序数据结构:最小堆. 最小堆是一种经过排序的完全二叉树,其中任一非终端节点数值均不大于其左孩子和右孩子节点的值. 可以得出结论,如果一棵二叉树满足 ...
- 计算机程序的思维逻辑 (47) - 堆和PriorityQueue的应用
45节介绍了堆的概念和算法,上节介绍了Java中堆的实现类PriorityQueue,PriorityQueue除了用作优先级队列,还可以用来解决一些别的问题,45节提到了如下两个应用: 求前K个最大 ...
- JVM学习(2)——技术文章里常说的堆,栈,堆栈到底是什么,从os的角度总结
俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及到的知识点总结如下: 堆栈是栈 JVM栈和本地方法栈划分 Java中的堆,栈和c/c++中的堆,栈 数据结构层面的堆,栈 os层面 ...
- 数据结构:优先队列 基于堆实现(python版)
#!/usr/bin/env python # -*- coding:utf-8 -*- ''' Author: Minion-Xu ''' #异常类 class HeapPriQueueError( ...
- 数据结构:堆排序 (python版) 小顶堆实现从大到小排序 | 大顶堆实现从小到大排序
#!/usr/bin/env python # -*- coding:utf-8 -*- ''' Author: Minion-Xu 小堆序实现从大到小排序,大堆序实现从小到大排序 重点的地方:小堆序 ...
- Java中堆内存和栈内存详解2
Java中堆内存和栈内存详解 Java把内存分成两种,一种叫做栈内存,一种叫做堆内存 在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配.当在一段代码块中定义一个变量时,ja ...
随机推荐
- vue项目中缓存问题
单页面应用总是存在缓存问题,特别是在微信端,更新页面之后访问的还是老页面,缓存的问题是因为用户访问的脚本地址并没有改变,浏览器就会读取原来的脚本 网上有几种解决办法,首先列举一下 1.加meta,禁止 ...
- Mysql 5.7 开启远程连接
1 在控制台执行 mysql -uroot -p 系统提示输入数据库root用户的密码,输入完成后即进入mysql控制台 2 选择数据库 mysql -uroot -p use mysql; 开启远程 ...
- python——元组(tuple)基本操作
元组被称为只读列表,数据可被查询,但不能被修改,类似于列表的切片操作,元组写在小括号里面()元素之前用逗号隔开 对于一些不想被修改的数据,可以用元组来保存 # 创建元组 1)创建空元组 # 创建空元 ...
- 002---time & datetime
time & datetime 时间模块 分类 时间戳 时间字符串 时间元祖 定义 UTC:格林威治时间,世界标准时间,中国(UTC + 8) 时间戳:1970-01-01 0:0:0 开始按 ...
- TCD产品技术参考资料
1.Willis环 https://en.wikipedia.org/wiki/Circle_of_Willis 2.TCD仿真软件 http://www.transcranial.com/index ...
- 在Ubuntu Server 16.04 LTS下安装VMware Tools
1.开启ubuntu server虚拟机 2.vmware workstation菜单项,选取虚拟机(M) --> 安装VMware Tools 3.mkdir /mnt/cdrom #创建一 ...
- 微信H5支付 在其他浏览器调用微信支付
微信H5支付的相关资料不是很多.不过步骤上来说不是很复杂 比公众号支付简单很多. 先上官方文档吧 https://pay.weixin.qq.com/wiki/doc/api/H5.php?chapt ...
- php长整型完整输出
今天调用webservice时返回一个字段是int64 长整型 原始的数值应该是 190000002101056096 而php返回时转成 1.9000000210106E+17 当传入另一个接口就报 ...
- ardupilot_gazebo仿真(一)
ardupilot_gazebo仿真 标签(空格分隔): 未分类 ardupilot_gazebo仿真 官网网址 代码更新地址 Ardupilot Gazebo Plugin & Models ...
- 阿里云服务器 linux下载 jdk
直接从本地下载包上传比较慢.直接在服务器上下载安装包: 1.进入orcle官网; 2.选择需要下载的版本,下载需要同意orcle协议, 3.点击下载,获取到下载请求的cookie, 复制所有cooki ...