hdu 6203 ping ping ping(LCA+树状数组)

题意:给一棵树,有m条路径,问至少删除多少个点使得这些路径都不连通

\(1 <= n <= 1e4\)

\(1 <= m <= 5e4\)

思路:

根据路径的LCA深度从大到小排序,每次选择一个没被删除的LCA删除

当某个点删除时,跨越了以这个点为根的子树的路径都会被割断,而排序保证在同一子树内部的路径已经被处理过了,子树信息可以用dfs序来表示,区间操作可以用左右端点打标记,用树状数组维护即可。

#include<bits/stdc++.h>
#define LL long long
using namespace std;
const int N = 1e4 + 10;
vector<int> G[N];
int tot,in[N],out[N];
int dep[N],f[N][20];
int n;
void dfs(int u,int fa,int d){
in[u] = ++tot;
f[u][0] = fa,dep[u] = d;
for(int i = 1;i < 20;i++) f[u][i] = f[f[u][i-1]][i-1];
for(auto v:G[u]) if(v != fa) dfs(v,u,d + 1);
out[u] = tot;
}
int lca(int u,int v){
if(dep[u] < dep[v]) swap(u,v);
int d = dep[u] - dep[v];
for(int i = 19;i >= 0 && u != v;i--) if(d & (1<<i)) u = f[u][i];
if(u == v) return u;
for(int i = 19;i >= 0;i--) if(f[u][i] != f[v][i]) u = f[u][i],v = f[v][i];
return f[u][0];
}
int tr[N];
int lowbit(int x){return x &(-x);}
void up(int pos,int c){
for(;pos <= n;pos += lowbit(pos)) tr[pos] += c;
}
int getsum(int pos){
int ans = 0;
for(;pos;pos -= lowbit(pos)) ans += tr[pos];
return ans;
}
struct Q{
int x,y,xy;
Q(){};
bool operator<(const Q&rhs)const{
return dep[xy] > dep[rhs.xy];
}
}qr[100010];
int main()
{
int u,v;
while(scanf("%d",&n)==1){
n++;
for(int i = 1;i <= n;i++) {
G[i].clear();
tr[i] = 0;
}
for(int i = 1;i < n;i++){
scanf("%d%d",&u,&v);u++,v++;
G[u].push_back(v);
G[v].push_back(u);
}
tot = 0;
dfs(1,0,0);
int q;
scanf("%d",&q);
for(int i = 0;i < q;i++){
scanf("%d%d",&u,&v);u++,v++;
qr[i].x = u,qr[i].y = v,qr[i].xy = lca(u,v);
}
sort(qr, qr + q);
int ans = 0;
for(int i = 0;i < q;i++){
if(getsum(in[qr[i].x]) || getsum(in[qr[i].y])) continue;
ans++;up(in[qr[i].xy],1),up(out[qr[i].xy]+1,-1);
}
cout<<ans<<endl;
}

hdu 6203 ping ping ping(LCA+树状数组)的更多相关文章

  1. hdu 5869 区间不同GCD个数(树状数组)

    Different GCD Subarray Query Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K ( ...

  2. HDU 6203 ping ping ping(dfs序+LCA+树状数组)

    http://acm.hdu.edu.cn/showproblem.php?pid=6203 题意: n+1 个点 n 条边的树(点标号 0 ~ n),有若干个点无法通行,导致 p 组 U V 无法连 ...

  3. HDU 2492 Ping pong(数学+树状数组)(2008 Asia Regional Beijing)

    Description N(3<=N<=20000) ping pong players live along a west-east street(consider the street ...

  4. POJ 3928 &amp; hdu 2492 &amp; Uva1428 PingPong 【树状数组】

    Ping pong                                                   Time Limit: 2000/1000 MS (Java/Others)   ...

  5. hdu 1394 Minimum Inversion Number(树状数组)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1394 题意:给你一个0 — n-1的排列,对于这个排列你可以将第一个元素放到最后一个,问你可能得到的最 ...

  6. HDU 5792 World is Exploding (树状数组)

    World is Exploding 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5792 Description Given a sequence ...

  7. HDU 5773 The All-purpose Zero(树状数组)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5773 [题目大意] 给出一个非负整数序列,其中的0可以替换成任意整数,问替换后的最长严格上升序列长 ...

  8. 【 HDU - 4456 】Crowd (二维树状数组、cdq分治)

    BUPT2017 wintertraining(15) #5A HDU 4456 题意 给你一个n行n列的格子,一开始每个格子值都是0.有M个操作,p=1为第一种操作,给格子(x,y)增加z.p=2为 ...

  9. HDU 5792 World is Exploding(树状数组+离散化)

    http://acm.split.hdu.edu.cn/showproblem.php?pid=5792 题意: 思路: lmin[i]:表示左边比第i个数小的个数. lmax[i]:表示左边比第i个 ...

随机推荐

  1. 微信小程序之公共组件写法

    我们要实现如下图功能 小程序一个公共的弹出组件,首先我们创建一个pop文件 然后在生成的pop.json文件中将component定义为true { "component": tr ...

  2. jquery之prop与attr区别。

    一切看下面代码示例<!DOCTYPE html> <html> <head> <title>全选和反选</title> <script ...

  3. Java : java基础(1)

    java编译器有常亮优化机制,如果是常量的计算,会直接判断常量计算结果的取值范围,如果是变量,则没办法判断计算取值范围,编译会异常(如两个byte类型的变量相加). java中的常量指的是用 stat ...

  4. 记一次防火墙导致greenplum装机失败及定位修复过程

    一.问题现象 20180201:15:06:25:028653 gpinitsystem:sdw1-2:gpadmin-[INFO]:--------------------------------- ...

  5. 20190105-打印字母C,H,N,口等图像和杨辉三角

    1. 打印字母C ****** * * * * ****** def print_c(n): print('*' * n) for i in range(n): print('* ') print(' ...

  6. 爬虫之request模块高级

    一.cookie&session cookie:服务器端使用cookie来记录客户端的状态信息 实现流程: 执行登陆操作(获取cookie) 在发起个人主页请求时,需要将cookie携带到该请 ...

  7. LINQ巩固

    LINQ巩固 LINQ过滤运算符 Where 基于谓词函数过滤值 测试例子如下: public class TestModel { public string Name { get; set; } p ...

  8. 【Leetcode】647. Palindromic Substrings

    Description Given a string, your task is to count how many palindromic substrings in this string. Th ...

  9. Java8新特性(一)——Lambda表达式与函数式接口

    一.Java8新特性概述 1.Lambda 表达式 2. 函数式接口 3. 方法引用与构造器引用 4. Stream API 5. 接口中的默认方法与静态方法 6. 新时间日期 API 7. 其他新特 ...

  10. samba与apache配置使用

    samba与apache根目录 1.直接将apache用户作为samba用户 2.给apache用户赋宇网站根目录的acl rwx权限 #注意 第一次不要加默认的权限 setfacl -m u:apa ...