洛谷P2982 [USACO10FEB]慢下来Slowing down
题目大意 :给出一棵树,节点有点权,求每个节点的祖先中点权小于该节点的结点的个数 。
思路如下 :
从根节点开始,对树进行深度优先遍历。
- 当进行到节点 i 时,有:
$\text{i}$ 的祖先们 $\text{Father[i]}$ 已经被访问过了,但还没有退出。
其他节点或者已经被访问过并退出了,或者还没有被访问。
那么需要一个数据结构,维护那些已经被访问过了,但还没有退出的点权,支持查询小于特定值的元素的数量 。
可以使用树状数组或者线段树。
Code
#include <cstdio>
#include <cstring>
#define re register
#define GC getchar()
#define Clean(X,K) memset(X,K,sizeof(X))
#define Lowbit(X) (X&(-X))
int Qread () {
int X = ; char C = GC ;
while (C > '' || C < '') C = GC ;
while (C >='' && C <='') {
X = X * + C - '' ;
C = GC ;
}
return X ;
}
const int Maxn = ;
int N , P_C[Maxn] , Ans[Maxn] , En = , Head[Maxn] , T[Maxn];
struct Edge {
int From_Where , Goto_Where , Next_Edge ;
};
Edge E[Maxn * ] ;
void Adg (int X , int Y) {
E[++En].From_Where = X ;
E[En].Goto_Where = Y ;
E[En].Next_Edge = Head[X] ;
Head[X] = En ;
}
void Add (int X , int K) {
while (X <= N) {
T[X] += K ;
X += Lowbit(X) ;
}
}
int Ask (int X) {
int Ans = ;
while (X > ) {
Ans += T[X] ;
X -= Lowbit(X) ;
}
return Ans ;
}
void Super_Powerful_DFS (int X , int Lst) {
Ans[P_C[X]] = Ask (P_C[X]) ;
//printf ("%d %d %d\n" , X , P_C[X],Ans[P_C[X]]) ;
Add (P_C[X] , ) ;
for (re int i = Head[X] ; i ; i = E[i].Next_Edge ) {
if (E[i].Goto_Where == Lst) continue ;
Super_Powerful_DFS ( E[i].Goto_Where , X) ;
}
Add (P_C[X] , -) ;
}
int main () {
//freopen ("P2982.in" , "r" , stdin) ;
Clean (Ans , ) , Clean (Head , ) , Clean (T , ) , En = ;
N = Qread () ;
for (re int i = ; i < N ; ++ i) {
int X = Qread () , Y = Qread () ;
Adg (X , Y) , Adg (Y , X) ;
}
for (re int i = ; i <= N; ++ i) {
int X = Qread () ;
P_C[X] = i ;
}
Super_Powerful_DFS ( , -) ;
for (re int i = ; i <= N; ++ i) printf ("%d\n" , Ans[i]) ;
fclose (stdin) ;
fclose (stdout);
return ;
}点击这里学习树状数组
Thanks !
洛谷P2982 [USACO10FEB]慢下来Slowing down的更多相关文章
- 洛谷P2982 [USACO10FEB]慢下来Slowing down [2017年四月计划 树状数组01]
P2982 [USACO10FEB]慢下来Slowing down 题目描述 Every day each of Farmer John's N (1 <= N <= 100,000) c ...
- 洛谷P2982 [USACO10FEB]慢下来Slowing down(线段树 DFS序 区间增减 单点查询)
To 洛谷.2982 慢下来Slowing down 题目描述 Every day each of Farmer John's N (1 <= N <= 100,000) cows con ...
- 洛谷 P2982 [USACO10FEB]慢下来Slowing down
题目描述 Every day each of Farmer John's N (1 <= N <= 100,000) cows conveniently numbered 1..N mov ...
- 洛谷——P2983 [USACO10FEB]购买巧克力Chocolate Buying
P2983 [USACO10FEB]购买巧克力Chocolate Buying 题目描述 Bessie and the herd love chocolate so Farmer John is bu ...
- 洛谷 P2983 [USACO10FEB]购买巧克力Chocolate Buying 题解
P2983 [USACO10FEB]购买巧克力Chocolate Buying 题目描述 Bessie and the herd love chocolate so Farmer John is bu ...
- 洛谷P2983 [USACO10FEB]购买巧克力Chocolate Buying
题目描述 Bessie and the herd love chocolate so Farmer John is buying them some. The Bovine Chocolate Sto ...
- 洛谷 P2983 [USACO10FEB]购买巧克力Chocolate Buying
购买巧克力Chocolate Buying 乍一看以为是背包,然后交了一个感觉没错的背包上去. #include <iostream> #include <cstdio> #i ...
- 洛谷 P2984 [USACO10FEB]给巧克力Chocolate Giving
题目描述 Farmer John is distributing chocolates at the barn for Valentine's day, and B (1 <= B <= ...
- 洛谷—— P2983 [USACO10FEB]购买巧克力Chocolate Buying
https://www.luogu.org/problem/show?pid=2983 题目描述 Bessie and the herd love chocolate so Farmer John i ...
随机推荐
- C# AESCBC256 与 java AESCBC256 加解密
和某上市公司对接接口,他们试用 java AES CBC PKCS5 256 加解密.网上C# 基本不合适. 注意:C# PKCS7 对应 java PKCS5 /// <summary> ...
- 如何通过setTimeout理解JS运行机制详解
setTimeout()函数:用来指定某个函数或某段代码在多少毫秒之后执行.它返回一个整数,表示定时器timer的编号,可以用来取消该定时器. 例子 ? 1 2 3 4 5 console.log(1 ...
- php小程序登录时解密getUserInfo获取openId和unionId等敏感信息
在获取之前先了解一下openId和unionId openId : 用户在当前小程序的唯一标识 unionId : 如果开发者拥有多个移动应用.网站应用.和公众帐号(包括小程序),可通过unionid ...
- 2018-04-27 搭建Python官方文档翻译环境-汉化示例代码
通过官方i18n流程, 实现文档中的代码段的汉化, 效果如下(4. More Control Flow Tools): 步骤 基于python官方3.6版文档cpython/Doc生成pot文件. 参 ...
- springboot 事务管理
添加注解就完事儿了 @Transactional 1,Propagation 事务的传播行为 Propagation.REQUIRED 如果存在事务,就加入,没有的话就创建(默认值) 比如 A 方法 ...
- Spotlight on Mysql详细介绍
Spotlight on Mysql详细介绍 by:授客 QQ:1033553122 1. 版本 2. 使用介绍 1) 主页 会话面板 MySQL面板 INNODB面板 存储面板 主机面板 ...
- Android Dialog对话框
Dialog的基本方法 //创建Dialog AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this); //设 ...
- Apktool(2)——使用前必须知道的apk知识
这里拿testapp.apk为例,如下图所示,左图为直接解压apk得到的文件,右图为apktool反编译得到的文件(反编译的使用在下一篇重点介绍) 图1 解压apk和反编译apk得到的文件目录对比 一 ...
- c++趣味之变量名,颠覆所有教科书的VisualStudio
GCC不参与这次的趣味. 所有的教程都会告诉你,c++的变量名,类名,函数名都应该是字母或下划线开头的字母.数字.下划线组合,像这样: int _abc123; 实际上,VisualStudio并不遵 ...
- 批量修改所有服务器的dbmail配置
最近遇到这样一个案例,需要修改所有SQL Server的Database Mail的SMTP,原来的SMTP为10.xxx.xxx.xxx, 现在需要修改为192.168.xxx.xxx, 另外需要规 ...