时间限制:C/C++ 2秒,其他语言4秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld

题目描述

wyf非常喜欢树。一棵有根数树上有N个节点,1号点是他的根,每条边都有一个距离,而wyf是个爱问奇怪问题的熊孩子,他想知道对于某个点x,以x为根的子树上,所有与x距离大于等于k的点与x的距离之和。

输入描述:

第一行一个正整数N

接下来N-1描述这棵树,每行两个数第i行两个数p和D表示树上有一条p到i+1长度为D的边。(p<=i)

下面一行一个正整数Q表示wyf的询问次数。

接下来Q行每行两个正整数x和k。 (1<=N,Q<=2x105,1<=D,K<=106)

输出描述:

对于每次询问x,k输出以x为根的子树上,所有与x距离大于等于k的点与x的距离之和。(若不存在这样的点,则输出应为0)

输入例子:
3
1 2
1 3
2
1 3
1 2
输出例子:
3
5

-->

示例1

输入

3
1 2
1 3
2
1 3
1 2

输出

3
5



#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=2e5+88;
long long ans[N];
int tot,head[N],pos[N],kt,lt[N];
struct cta{
 int next,to,w;
}e[N<<1];
struct node{
 int num,l,r;
 long long sum;
}tr[N<<2];
struct qqq{
 int id,rto;
 long long k;
 bool operator <(const qqq &A)const{
 return k>A.k;
 }
}qt[N];
struct ttt{
 long long dis;
 int id;
 bool operator < (const ttt &B)const{
   return dis>B.dis;
 }
}dt[N];
void add(int u,int v,int w) {
 e[tot].to=v;e[tot].next=head[u];e[tot].w=w;head[u]=tot++;
}
void build(int l,int r,int rt){
 tr[rt].l=l,tr[rt].r=r;
 tr[rt].sum=tr[rt].num=0;
 if(l==r) return;
 int mid=(l+r)>>1;
 build(l,mid,rt<<1);
 build(mid+1,r,rt<<1|1);
}
void dfs(int u,long long now,int f){
 pos[u]=++kt;
 for(int i=head[u];~i;i=e[i].next)  {
 if(e[i].to==f) continue;
 else dfs(e[i].to,dt[e[i].to].dis=e[i].w+now,u);
 }
 lt[u]=kt;
}
void modify(int pos,int rt,int cc){
 int l=tr[rt].l,r=tr[rt].r;
 int mid=(l+r)>>1;
 if(l==r) {
  tr[rt].num=1;
  tr[rt].sum+=dt[cc].dis;
     return;}
 if(pos<=mid) modify(pos,rt<<1,cc);
 else modify(pos,rt<<1|1,cc);
 tr[rt].num=tr[rt<<1].num+tr[rt<<1|1].num;
 tr[rt].sum=tr[rt<<1].sum+tr[rt<<1|1].sum;
}
long long query(int L,int R,int rt,long long &cty){
 long long now=0;
 if(L>R) return 0;
 int l=tr[rt].l,r=tr[rt].r;
 if(L<=l&&R>=r) {cty+=tr[rt].num; return tr[rt].sum;}
 int mid=(l+r)>>1;
 if(mid>=L) now+=query(L,R,rt<<1,cty);
 if(mid<R) now+=query(L,R,rt<<1|1,cty);
 return now;
}
int tran[N];
int main(){
 int n,x,y,m;
 memset(head,-1,sizeof(head));
 tot=kt=0;
 scanf("%d",&n);
 build(1,n,1);
 for(int i=2;i<=n;++i) {
  scanf("%d%d",&x,&y);
  add(x,i,y);
  add(i,x,y);
 }
 dfs(1,0,0);
 for(int i=1;i<=n;++i) dt[i].id=i;
 scanf("%d",&m);
 for(int i=1;i<=m;++i) {
  scanf("%d%lld",&qt[i].rto,&qt[i].k);
  qt[i].id=i;
  qt[i].k+=dt[qt[i].rto].dis;
 }
 sort(qt+1,qt+1+m);
 sort(dt+1,dt+n+1);
 int r=1;
 for(int i=1;i<=n;++i) tran[dt[i].id]=i;
 for(int i=1;i<=m;++i) {
     long long now=0;
     for(;r<=n;++r) if(!(dt[r].dis>=qt[i].k)) break;else modify(pos[dt[r].id],1,r);
     ans[qt[i].id]=query(pos[qt[i].rto]+1,lt[qt[i].rto],1,now);
     ans[qt[i].id]-=now*dt[tran[qt[i].rto]].dis;
 }
 for(int i=1;i<=m;++i) printf("%lld\n",ans[i]);
}

wannafly挑战赛4树的距离 离线处理,dfs序的更多相关文章

  1. newcoder Wannafly挑战赛4 树的距离

    https://www.nowcoder.com/acm/contest/35/D 假设要查询x的子树中,与x的距离>=y的距离和 那么如果有这么一个 由x的子树中的点到x的距离构成的序列,且按 ...

  2. 【bzoj4771】七彩树 树链的并+STL-set+DFS序+可持久化线段树

    题目描述 给定一棵n个点的有根树,编号依次为1到n,其中1号点是根节点.每个节点都被染上了某一种颜色,其中第i个节点的颜色为c[i].如果c[i]=c[j],那么我们认为点i和点j拥有相同的颜色.定义 ...

  3. Bzoj 4034: [HAOI2015]T2 树链剖分,子树问题,dfs序

    4034: [HAOI2015]T2 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1841  Solved: 598[Submit][Status] ...

  4. BZOJ4530 BJOI2014大融合(线段树合并+并查集+dfs序)

    易知所求的是两棵子树大小的乘积.先建出最后所得到的树,求出dfs序和子树大小.之后考虑如何在动态加边过程中维护子树大小.这个可以用树剖比较简单的实现,但还有一种更快更优美的做法就是线段树合并.对每个点 ...

  5. bzoj4817/luogu3703 树点涂色 (LCT+dfs序+线段树)

    我们发现,这个染色的操作他就很像LCT中access的操作(为什么??),然后就自然而然地想到,其实一个某条路径上的颜色数量,就是我们做一个只有access操作的LCT,这条路径经过的splay的数量 ...

  6. BZOJ.4817.[SDOI2017]树点涂色(LCT DFS序 线段树)

    题目链接 操作\(1.2\)裸树剖,但是操作\(3\)每个点的答案\(val\)很不好维护.. 如果我们把同种颜色的点划分到同一连通块中,那么向根染色的过程就是Access()! 最初所有点间都是虚边 ...

  7. 沈阳网络赛J-Ka Chang【分块】【树状数组】【dfs序】

    Given a rooted tree ( the root is node 11 ) of NN nodes. Initially, each node has zero point. Then, ...

  8. 【AC自动机】【树状数组】【dfs序】洛谷 P2414 [NOI2011]阿狸的打字机 题解

        这一题是对AC自动机的充分理解和树dfs序的巧妙运用. 题目背景 阿狸喜欢收藏各种稀奇古怪的东西,最近他淘到一台老式的打字机. 题目描述 打字机上只有28个按键,分别印有26个小写英文字母和' ...

  9. 【树链剖分】【dfs序】【线段树】bzoj2836 魔法树

    这道题告诉我们:树链剖分的重标号就是dfs序. #include<cstdio> #include<algorithm> using namespace std; #defin ...

随机推荐

  1. libcurl库返回状态码解释与速查

    libcurl库返回状态码解释与速查     CURLE_OK(0) 支持返回 CURLE_UNSUPPORTED_PROTOCOL(1) 你的URL传递给libcurl的使用协议,这libcurl的 ...

  2. SpringBoot 集成Swagger2自动生成文档和导出成静态文件

    目录 1. 简介 2. 集成Swagger2 2.1 导入Swagger库 2.2 配置Swagger基本信息 2.3 使用Swagger注解 2.4 文档效果图 3. 常用注解介绍 4. Swagg ...

  3. ubuntu 下 使用GTK+、sqlite3、c语言的学生系统

    使用GTK+2.0.sqlite3数据库.c语言 的简易的学生管理系统 实现了基本的增删查改 效果图:

  4. 【集群实战】inotify

    1. inotify简介 Inotify是一种强大的,细粒度的,异步的文件系统事件监控机制(软件). linux内核从2.6.13起,加入了Inotify支持,通过Inotify可以监控文件系统中添加 ...

  5. Gartner:2016 Q2全球服务器市场,中国再度成为亮点

    对于IT产品供应商来说,Gartner.IDC等第三方分析机构市场调研报告无疑是一次"中考",成绩优异的论功行赏,迎接鲜花和掌声:差强人意,批斗会将是不可避免的,接下来加班加点,力 ...

  6. Docker安装和基本操作

    一.Docker安装 CentOS7安装Docker CE $sudo yum install -y yum-utils device-mapper-persistent-data lvm2 $sud ...

  7. 如何在Vue项目中优雅的使用swiper插件

    个人网站 https://iiter.cn 程序员导航站 开业啦,欢迎各位观众姥爷赏脸参观,如有意见或建议希望能够不吝赐教! 开始之前,请先确保有一个基于webpack模板的项目(vue-cli脚手架 ...

  8. 关于 cmd 命令运行时发现错误(已加 classpath): 找不到或无法加载主类 xxx.class 原因: Java .lang.ClassNotFoundException: xxx.class

    我的是这个代码,出现了,无法加载主类的问题,查看了一些回答,有的是说要删除包名(我的没有带包,所以不是这个问题),还有的是说classpath的配置有问题,但是我的java ,javac测试jdk的时 ...

  9. 数据库SQL语言从入门到精通--Part 4--SQL语言中的模式、基本表、视图

    数据库从入门到精通合集(超详细,学习数据库必看) 前言: 使用SQL语言时,要注意SQL语言对大小写并不敏感,一般使用大写.所有符号一定是西文标点符号(虽然是常识,但我还是提一嘴) 1.模式的定义与删 ...

  10. 【MIT6.828】centos7下使用Qemu搭建xv6运行环境

    title:[MIT6.828]centos7下使用Qemu搭建xv6运行环境 date: "2020-05-05" [MIT6.828]centos7下搭建xv6运行环境 1. ...