HDU 5877 Weak Pair(弱点对)
HDU 5877 Weak Pair(弱点对)
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)
|
Description |
题目描述 |
|
You are given a rooted tree of N nodes, labeled from 1 to N. To the ith node a non-negative value ai is assigned. An ordered pair of nodes (u,v) is said to be weak if (1) u is an ancestor of v (Note: In this problem a node u is not considered an ancestor of itself); (2) au × av ≤ k. Can you find the number of weak pairs in the tree? |
给你有N个节点的有根树,编号从1到N。第i个节点会被分配一个非负数ai。一个满足如下条件的有序点对(u, v)则被认为是弱点对 (1)u是v的先祖节点(注意:这个问题中u不能为自身的先祖节点)。 (2) au X av ≤ k 你能找出这棵树里有多少弱点对吗? |
|
Input |
输入 |
|
There are multiple cases in the data set. The first line of input contains an integer T denoting number of test cases. For each case, the first line contains two space-separated integers, N and k, respectively. The second line contains N space-separated integers, denoting a1 to aN. Each of the subsequent lines contains two space-separated integers defining an edge connecting nodes u and v , where node u is the parent of node v. Constrains: 1≤N≤105 0≤ai≤109 0≤k≤1018 |
多组测试用例。 输入的第一行有一个整数T表示测试用例的数量。 对于每个测试用例,第一行有两个用空格分隔的整数,N与k, 第二行有N个用空格分隔的整数,表示a1到aN。 随后每(N-1)行有两个用空格分隔的数u与v表示连接两节点的一条边,其中u是v的父节点。 范围如下: 1≤N≤105 0≤ai≤109 0≤k≤1018 |
|
Output |
输出 |
|
For each test case, print a single integer on a single line denoting the number of weak pairs in the tree. |
对于每个测试用例,输出一个表示树中弱点对数量的整数在单独一行。 |
|
Sample Input - 输入样例 |
Sample Output - 输出样例 |
|
1 |
1 |
【题解】
DFS + 离散化线段树
用DFS从上往下(从根往叶子)添加与释放节点进线段树,利用线段树查找符合的区间中元素数量。
因为单个数的值比较大,但是总数比较少,线段树还算可以接受。根据总数进行离散化,其实就是排个序+map。出于想用upper_bound的强迫症没有把k/ai的结果一并加入离散化(注意0),不然代码量应该更少。
【代码 C++】
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <map>
#define LL __int64
#define mx 100005
std::map<LL, int> mp;
LL data[mx], dMP[mx], opt, k;
int n; struct Edge{
int to, next;
}edge[mx];
int iE, head[mx], d[mx], tr[mx << ], fid;
void addEdge(int u, int v){
edge[iE].to = v; edge[iE].next = head[u]; head[u] = iE++;
} void cnt(int l, int r, int now){
if (r <= fid){ opt += tr[now]; return; }
int mid = l + r >> ;
if (fid <= mid) return cnt(l, mid, now << );
opt += tr[now << ]; return cnt(mid + , r, now << | );
}
void sub(int l, int r, int now){
--tr[now];
if (l == r) return;
int mid = l + r >> ;
if (fid <= mid) return sub(l, mid, now << );
return sub(mid + , r, now << | );
}
void add(int l, int r, int now){
++tr[now];
if (l == r) return;
int mid = l + r >> ;
if (fid <= mid) return add(l, mid, now << );
return add(mid + , r, now << | );
} void DFS(int now){
int u;
LL temp;
if (data[now] == || (temp = k / data[now]) >= dMP[n]) fid = n;
else fid = std::upper_bound(dMP + , dMP + + n, temp) - dMP - ;
if (fid) cnt(, n, );
fid = mp[data[now]]; add(, n, );
for (u = head[now]; ~u; u = edge[u].next) DFS(edge[u].to);
fid = mp[data[now]]; sub(, n, );
} int main(){
int t, i, u, v;
scanf("%d", &t);
while (t--){
mp.clear(); memset(tr, , sizeof(tr));
scanf("%d%I64d", &n, &k);
for (i = ; i <= n; ++i) scanf("%I64d", &data[i]);
memcpy(dMP, data, sizeof(data));
std::sort(dMP + , dMP + n + );
for (i = ; i <= n; ++i) mp[dMP[i]] = i; memset(head, -, sizeof(head)); memset(d, , sizeof(d));
iE = ;
for (i = ; i < n; ++i){
scanf("%d%d", &u, &v);
addEdge(u, v); ++d[v];
} for (i = ; d[i]; ++i);
opt = ; DFS(i);
printf("%I64d\n", opt);
}
return ;
}
HDU 5877 Weak Pair(弱点对)的更多相关文章
- 树形DP+树状数组 HDU 5877 Weak Pair
//树形DP+树状数组 HDU 5877 Weak Pair // 思路:用树状数组每次加k/a[i],每个节点ans+=Sum(a[i]) 表示每次加大于等于a[i]的值 // 这道题要离散化 #i ...
- hdu 5877 Weak Pair (Treap)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5877 题面; Weak Pair Time Limit: 4000/2000 MS (Java/Other ...
- 2016 ACM/ICPC Asia Regional Dalian Online HDU 5877 Weak Pair treap + dfs序
Weak Pair Problem Description You are given a rooted tree of N nodes, labeled from 1 to N. To the ...
- HDU - 5877 Weak Pair (dfs+树状数组)
题目链接:Weak Pair 题意: 给出一颗有根树,如果有一对u,v,如果满足u是v的父节点且vec[u]×vec[v]<=k,则称这对结点是虚弱的,问这棵树中有几对虚弱的结点. 题解: 刚开 ...
- HDU 5877 Weak Pair (2016年大连网络赛 J dfs+反向思维)
正难则反的思想还是不能灵活应用啊 题意:给你n个点,每个点有一个权值,接着是n-1有向条边形成一颗有根树,问你有多少对点的权值乘积小于等于给定的值k,其中这对点必须是孩子节点与祖先的关系 我们反向思考 ...
- hdu 5877 Weak Pair dfs序+树状数组+离散化
Weak Pair Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others) Prob ...
- HDU 5877 Weak Pair(树状数组)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5877 [题目大意] 给出一棵带权有根树,询问有几对存在祖先关系的点对满足权值相乘小于等于k. [题 ...
- HDU 5877 Weak Pair(树状数组+dfs+离散化)
http://acm.hdu.edu.cn/showproblem.php?pid=5877 题意: 给出一棵树,每个顶点都有权值,现在要你找出满足要求的点对(u,v)数,u是v的祖先并且a[u]*a ...
- HDU 5877 Weak Pair DFS + 树状数组 + 其实不用离散化
http://acm.hdu.edu.cn/listproblem.php?vol=49 给定一颗树,然后对于每一个节点,找到它的任何一个祖先u,如果num[u] * num[v] <= k.则 ...
随机推荐
- D5转Xe点滴
1. VarIsNull 函数已经被 Variants 单元, 相应的 Var 相关都放在哪 2.原本在 SysUtils 下的部分格式函数或定义,例如 .DecimalSeparator: Sho ...
- php的ssh2扩展安装
折腾半天,结论如下: 1.先需要openssl 用which openssl看是否已安装 2.然后libssh2 用rpm -ql libssh2查看 3.下载源码的shh2x.x.x.tgz的包 4 ...
- java数组初始化
java数组初始化 //静态初始化数组:方法一 String cats[] = new String[] { "Tom","Sam","Mimi&qu ...
- Hibernate,JPA注解@PrimaryKeyJoinColumn
一对一(One-to-one),主键关联 用例代码如下: 数据库DDL语句 1,CAT表 create table CAT ( id CHAR) not null, create_time ), up ...
- (java)==和equals()的使用小结
1.如果两个变量说基本数据类型,且都是数值类型,eg.65f,65(不一定要求数据类型严格相同),只要两个变量的值相等,就将返回true int it=65; float fl=65.0f; char ...
- css3 动画 执行一次
function testAnim(x) { $('#animationSandbox').removeClass().addClass(x + ' animated').one('webkitA ...
- java静态块
一般情况下,如果有些代码必须在项目启动的时候就执行的时候,需要使用静态代码块,这种代码是主动执行的 静态代码块的初始化顺序 class Parent{ static String name = &q ...
- HttpClient的使用方法
使用httpClient发送请求.接收响应很简单.一般需要以下几个步骤. 第一:创建HttpClient对象: 第二:创建请求方法的实例,并指定请求URL.如果要发送GET请求,创建HttpGet对象 ...
- ThreadLocal的使用及介绍
ThreadLocal总结 1.ThreadLocal使用场合主要解决多线程中数据数据因并发产生不一致问题.ThreadLocal为每个线程的中并发访问的数据提供一个副本,通过访问副本来运行业务,这样 ...
- Network 分类: POJ 图论 2015-07-27 17:18 17人阅读 评论(0) 收藏
Network Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 14721 Accepted: 5777 Special Judg ...