D. Water Tree
4 seconds
256 megabytes
standard input
standard output
Mad scientist Mike has constructed a rooted tree, which consists of n vertices. Each vertex is a reservoir which can be either empty or filled with water.
The vertices of the tree are numbered from 1 to n with the root at vertex 1. For each vertex, the reservoirs of its children are located below the reservoir of this vertex, and the vertex is connected with each of the children by a pipe through which water can flow downwards.
Mike wants to do the following operations with the tree:
- Fill vertex v with water. Then v and all its children are filled with water.
- Empty vertex v. Then v and all its ancestors are emptied.
- Determine whether vertex v is filled with water at the moment.
Initially all vertices of the tree are empty.
Mike has already compiled a full list of operations that he wants to perform in order. Before experimenting with the tree Mike decided to run the list through a simulation. Help Mike determine what results will he get after performing all the operations.
The first line of the input contains an integer n (1 ≤ n ≤ 500000) — the number of vertices in the tree. Each of the following n - 1 lines contains two space-separated numbers ai, bi (1 ≤ ai, bi ≤ n, ai ≠ bi) — the edges of the tree.
The next line contains a number q (1 ≤ q ≤ 500000) — the number of operations to perform. Each of the following q lines contains two space-separated numbers ci (1 ≤ ci ≤ 3), vi (1 ≤ vi ≤ n), where ci is the operation type (according to the numbering given in the statement), and vi is the vertex on which the operation is performed.
It is guaranteed that the given graph is a tree.
For each type 3 operation print 1 on a separate line if the vertex is full, and 0 if the vertex is empty. Print the answers to queries in the order in which the queries are given in the input.
5
1 2
5 1
2 3
4 2
12
1 1
2 3
3 1
3 2
3 3
3 4
1 2
2 4
3 1
3 3
3 4
3 5
0
0
0
1
0
1
0
1
思路:dfs序+线段树;
先dfs将点映射成线性的,然后维护两棵线段树,一个是往里面灌水的时间,一个是抽水的时间,抽水的时候是单点往上更新,因为这个点的
如果是某个点的字节点,那么查询这个这个父亲节点点所包含的子树时一点包含要更新的点,然后每个节点的灌水和抽水的最晚的时间就可以了,
然后两次查询比较时间先后就可以了。
复杂度n×log(n);
1 #include<stdio.h>
2 #include<math.h>
3 #include<queue>
4 #include<algorithm>
5 #include<string.h>
6 #include<iostream>
7 #include<stack>
8 #include<vector>
9 using namespace std;
10 typedef long long LL;
11 typedef vector<int>Ve;
12 vector<Ve>vec(600000);
13 int ans[600000];
14 int id[600000];
15 bool flag[600000];
16 int cn = 0;
17 int l[600000];
18 int r[600000];
19 int pre[600000];
20 void dfs(int n);
21 int tree1[600000*4];
22 int tree0[600000*4];
23 int query(int l,int r,int k,int nn,int mm,int *tr,int c);
24 void update(int l,int r,int k,int nn,int mm,int *tr,int i,int c);
25 int main (void)
26 {
27 int n,x,y;
28 scanf("%d",&n);
29 for(int i = 0; i < n-1; i++)
30 {
31 scanf("%d %d",&x,&y);
32 vec[x].push_back(y);
33 vec[y].push_back(x);
34 }
35 dfs(1);
36 for(int i = 1; i <= n; i++)
37 id[ans[i]] = i;
38 int m;
39 scanf("%d",&m);
40 int ccn = 0;
41 while(m--)
42 {
43 int val,c;
44 ++ccn;
45 scanf("%d %d",&val,&c);
46 if(val == 1)
47 {
48 update(l[c],r[c],0,1,cn,tree1,ccn,1);
49 //printf("%d\n",ccn);
50 }
51 else if(val == 2)
52 {
53 update(id[c],id[c],0,1,cn,tree0,ccn,0);
54 }
55 else
56 {
57 int a = query(id[c],id[c],0,1,cn,tree1,1);
58 int b = query(l[c],r[c],0,1,cn,tree0,0);
59 //printf("%d %d\n",a,b);
60 printf("%d\n",a>b);
61 }
62 }
63 return 0;
64 }
65 void dfs(int n)
66 {
67 flag[n] = true;
68 ans[++cn] = n;
69 l[n] = cn;
70 for(int i = 0; i < vec[n].size(); i++)
71 {
72 int ic = vec[n][i];
73 if(!flag[ic])
74 pre[ic] = n,dfs(ic);
75 }
76 r[n] = cn;
77 }
78 void update(int l,int r,int k,int nn,int mm,int *tr,int i,int c)
79 {
80 if(l > mm||r < nn)
81 {
82 return ;
83 }
84 else if(l <= nn&&r >= mm)
85 {
86 tr[k] = max(tr[k],i);
87 }
88 else
89 {
90 if(tr[k]&&c == 1)tr[2*k+1] = tr[k],tr[2*k+2] = tr[k],tr[k] = 0;
91 update(l,r,2*k+1,nn,(nn+mm)/2,tr,i,c);
92 update(l,r,2*k+2,(nn+mm)/2+1,mm,tr,i,c);
93 if(c == 0)
94 tr[k] = max(tr[k],tr[2*k+1]),tr[k] = max(tr[k],tr[2*k+2]);
95 }
96 }
97 int query(int l,int r,int k,int nn,int mm,int *tr,int c)
98 {
99 if(l > mm||r < nn)
100 {
101 return 0;
102 }
103 else if(l <= nn&&r >= mm)
104 {
105 return tr[k];
106 }
107 else
108 { if(c&&tr[k])tr[2*k+1] = tr[k],tr[2*k+2] = tr[k],tr[k] = 0;
109 int nx = query(l,r,2*k+1,nn,(nn+mm)/2,tr,c);
110 int ny = query(l,r,2*k+2,(nn+mm)/2+1,mm,tr,c);
111 return max(nx,ny);
112 }
113 }
D. Water Tree的更多相关文章
- Codeforces Round #200 (Div. 1) D Water Tree 树链剖分 or dfs序
Water Tree 给出一棵树,有三种操作: 1 x:把以x为子树的节点全部置为1 2 x:把x以及他的所有祖先全部置为0 3 x:询问节点x的值 分析: 昨晚看完题,马上想到直接树链剖分,在记录时 ...
- Codeforces Round #200 (Div. 1)D. Water Tree dfs序
D. Water Tree Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/343/problem/ ...
- 【题解】Luogu CF343D Water Tree
原题传送门:CF343D Water Tree 这道题要用树链剖分,我博客里有对树链剖分的详细介绍 这明显是弱智题 树剖套珂朵莉树多简单啊 前置芝士:珂朵莉树 窝博客里对珂朵莉树的介绍 没什么好说的自 ...
- Codeforces Round #200 (Div. 1) D. Water Tree 树链剖分+线段树
D. Water Tree time limit per test 4 seconds memory limit per test 256 megabytes input standard input ...
- Water Tree(树链剖分+dfs时间戳)
Water Tree http://codeforces.com/problemset/problem/343/D time limit per test 4 seconds memory limit ...
- xtu summer individual 6 F - Water Tree
Water Tree Time Limit: 4000ms Memory Limit: 262144KB This problem will be judged on CodeForces. Orig ...
- 343D/Codeforces Round #200 (Div. 1) D. Water Tree dfs序+数据结构
D. Water Tree Mad scientist Mike has constructed a rooted tree, which consists of n vertices. Each ...
- Water Tree CodeForces 343D 树链剖分+线段树
Water Tree CodeForces 343D 树链剖分+线段树 题意 给定一棵n个n-1条边的树,起初所有节点权值为0. 然后m个操作, 1 x:把x为根的子树的点的权值修改为1: 2 x:把 ...
- Codeforces 343D Water Tree 分类: Brush Mode 2014-10-05 14:38 98人阅读 评论(0) 收藏
Mad scientist Mike has constructed a rooted tree, which consists of n vertices. Each vertex is a res ...
随机推荐
- 创建一个vue实例
创建一个vue实例 每个 Vue 应用都是通过用 Vue 函数创建一个新的 Vue 实例开始的: var vm = new Vue({ // 选项 }) 虽然没有完全遵循 MVVM 模型,但是 Vue ...
- Spring DAO
Spring DAO 连接池 使用JDBC访问数据库是,频繁的打开连接和关闭连接,造成性能影响,所以有了连接池.数据库连接池负责分配.管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接, ...
- day06 HTTP协议
day06 HTTP协议 HTTP协议 什么是http? HTTP 全称:Hyper Text Transfer Protocol 中文名:超文本传输协议 是一种按照URL指示,将超文本文档从一台主机 ...
- 强化学习实战 | 表格型Q-Learning玩井字棋(二)
在 强化学习实战 | 表格型Q-Learning玩井字棋(一)中,我们构建了以Game() 和 Agent() 类为基础的框架,本篇我们要让agent不断对弈,维护Q表格,提升棋力.那么我们先来盘算一 ...
- 【leetcode】15. 3 Sum 双指针 压缩搜索空间
Given an integer array nums, return all the triplets [nums[i], nums[j], nums[k]] such that i != j, i ...
- Android Handler 消息机制原理解析
前言 做过 Android 开发的童鞋都知道,不能在非主线程修改 UI 控件,因为 Android 规定只能在主线程中访问 UI ,如果在子线程中访问 UI ,那么程序就会抛出异常 android.v ...
- 最新的Android Sdk 使用Ant多渠道批量打包
实例工程.所需的文件都在最后的附件中. 今天花费了几个小时,参考网上的资料,期间遇到了好几个问题, 终于实现了使用Ant批量多渠道打包,现在,梳理一下思路,总结使用Ant批量多渠道打包的方法:1 ...
- C++ 类型转换(C风格的强制转换):
转https://www.cnblogs.com/Allen-rg/p/6999360.html C++ 类型转换(C风格的强制转换): 在C++基本的数据类型中,可以分为四类:整型,浮点型,字符型, ...
- Spring Cloud Feign原理详解
目录 1.什么是Feign? 2.Open Feign vs Spring Cloud Feign 2.1.OpenFeign 2.2.Spring Cloud Open Feign 3.Spring ...
- springboot-MVC 过滤器使用
一.前言 一下代码以SSO用户登录列子代码.完整代码https://gitee.com/xuxueli0323/xxl-sso 二.使用 2.1 创建过滤器 创建一个过滤器,实现Filter 接口 p ...