题目描述
IcePrincess_1968 和 IcePrince_1968 长大了,他们开始协助国王 IceKing_1968 管理国内事物。

IcePrincess_1968 和 IcePrince_1968 住在一个宁静悠远的王国:IceKingdom —— 飘雪圣域。飘雪圣域有 n 个城镇,编号 1,2,3…n。有些城镇之间有道路,且满足任意两点之间有且仅有一条路径。飘雪圣域风景优美,但气候并不是太好。根据 IcePrince_1968 的气候探测仪,将来会发生 q 场暴风雪。每场暴风雪可以用两个整数 li,ri 刻画,表示这场暴风雪之后,只有编号属于[li,ri]的城市没有受到暴风雪的影响。

在暴风雪的影响下迅速确定王国的农业生产方案是非常重要的事情。IceKing_1968 认为,一个农业生产地域应该是一个极大连通块,满足每个节点都没有被暴风雪影响。这里极大连通块的定义是:不存在一个不属于该点集的未被暴风雪影响的点与该连通块连通。

IcePrincess_1968 要负责算出每次暴风雪后,王国能拥有多少个农业生产地域。注意这里每次暴风雪是独立的,即每次暴风雪过后,直到每个城镇重新焕发生机,下一次暴风雪才会到来。

正如上文所述,IcePrincess_1968 擅长文学但不擅长计算机,于是请你帮忙。

输入格式
第一行包含两个正整数 n,q,表示 IceKingdom 的城镇个数和暴风雪次数。

第2至第 n 行,每行两个正整数 x,y,表示城镇 x 和城镇 y 之间有一条道路。

第n+1 至第 n+q 行,每行两个正整数 li,ri,描述一场暴风雪,含义如题面所述。

输出格式
输出文件共有 q 行,第 i 行表示在第 i 场暴风雪之后农业生产地域的个数。

样例
样例输入
4 3
1 2
2 3
2 4
1 2
1 3
3 4
样例输出
1
1
2
数据范围与提示
【输入输出样例 1 解释】

第一次询问,只有(1,2)一个连通块。

第二次询问,只有(1,2,3)一个连通块。

第三次询问,有 3 和 4 两个连通块。

【输入输出样例 2】

见选手目录下的icekingdom/icekingdom2.in 和icekingdom/icekingdom2.ans。

【数据规模和约定】

对于30%的数据:n<=100,q<=100;

对于50%的数据:n<=2,000,q<=2,000;

对于100%的数据:n<=200,000,q<=200,000,对于所有的暴风雪,li<=ri。

来源
noip2018模拟-南外
题解:
不知为何,可能在洞穴探测的影响下,我成功的跑偏,走上了一条不归路
首先,给出一个性质:
树上两个连通块间有且只有一条连边!!
所以我们可以根据边的个数来判断有几个连通块!!!
这样就自然地想到离线。
orz

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
#define N 200005
using namespace std;
int n,q;
struct node
{int x,y;
}bian[N];int c[N];
inline int lowbit(int x){return x&(-x);}
inline void add(int x,int val){for(;x<=n;x+=lowbit(x))c[x]+=val;
}struct Ask
{int l,r,i;
}ask[N];
inline int get(int x){int sum=0;for(;x;x-=lowbit(x))sum+=c[x];return sum;
}
int ans[N];
bool cmp(node a,node b){return a.y<b.y;}
bool cm(Ask a,Ask b){return a.r<b.r;}
int main()
{cin>>n>>q;for(int i=1;i<n;++i){cin>>bian[i].x>>bian[i].y;if(bian[i].x>bian[i].y)swap(bian[i].x,bian[i].y);}sort(bian+1,bian+n,cmp);for(int i=1;i<=q;++i){cin>>ask[i].l>>ask[i].r;ask[i].i=i;}sort(ask+1,ask+1+q,cm);for(int i=1,j=1;i<=q;++i){while(bian[j].y<=ask[i].r&&j<n){add(bian[j].x,1);++j;}ans[ask[i].i]=ask[i].r-ask[i].l+1-get(ask[i].r)+get(ask[i].l-1);}for(int i=1;i<=q;++i)cout<<ans[i]<<endl;return 0;
}

#3985. 飘雪圣域(icekingdom)相关推荐

  1. 飘雪圣域(icekingdom)

    飘雪圣域(icekingdom) 题目描述 IcePrincess_1968 和 IcePrince_1968 长大了,他们开始协助国王 IceKing_1968 管理国内事物. IcePrinces ...

  2. ssoj3985: 飘雪圣域(icekingdom)

    时间限制: 1 Sec 内存限制: 256 MB 提交: 36 解决: 19 [提交][状态][博客][加入收藏] 题目描述 IcePrincess_1968 和 IcePrince_1968 长大了 ...

  3. 【提高测试】飘雪圣域(树状数组)

    描述 ​ IcePrincess_1968 和 IcePrince_1968 长大了,他们开始协助国王 IceKing_1968 管理国内事物. ​ IcePrincess_1968 和 IcePri ...

  4. 【数据结构】【离线操作】飘雪圣域

    ​ [题目描述] IcePrincess_1968 和 IcePrince_1968 长大了,他们开始协助国王 IceKing_1968 管理国内事物. ​ IcePrincess_1968 和 Ic ...

  5. 20190218【梦境】【玩具】【飘雪圣域】

    贪心 玄学DP 树状数组 T1[梦境] WOJ 707070分 网络流跑二分图 #include<bits/stdc++.h> using namespace std; inline in ...

  6. 飘雪圣域 [树状数组(二维偏序)]

    飘 雪 圣 域 飘雪圣域 飘雪圣域 正 解 部 分 \color{red}{正解部分} 正解部分 首 先 要 知 道 : 首先要知道: 首先要知道: 若给定一个区间 [ l , r ] [l, r] ...

  7. 【JZOJ6285】飘雪圣域

    description analysis 从求联通块出发根本没做法,于是考虑连通块里面的边 对于一个询问 [ l , r ] [l,r] [l,r],一条边的左端点 ≥ l ≥l ≥l且右端点 ≤ r ...

  8. [WOJ4379] 飘雪圣域 [主席树]

    传送门 每次询问点的个数是r-l+1, 那么联通块个数就是总点数减去边的个数 考虑哪些边有贡献, 令边为l,r (l<r), 那么ql <= l < r <= qr 的边有贡献 ...

  9. [树状数组]飘雪圣域

    没找到传送门(这是校内的) 题意:给一棵树,多次询问编号在l到r中的点组成的连通块个数 考试的时候一直在想奇怪的做法,用的都是树上维护的知识(比如已经被某C姓神仙卡掉的虚树+树剖+二分) 其实这道题根 ...

最新文章

  1. 2022-2028年中国再生橡胶制造行业市场专项调研及投资前景规划报告
  2. Node.js 文件系统流pipe到Http响应流中
  3. 使用hive中beeline引擎来访问hive数据库
  4. 全国计算机等级考试题库二级C操作题100套(第19套)
  5. 零配置 之 Spring 注解实现Bean依赖注入
  6. android客户端从服务器端获取json数据并解析的实现代码
  7. Python线程同步机制
  8. Android常用Adapter用例(二)
  9. hadoop jps 没有命令_hadoop:伪分布模式启动步骤分解
  10. Latex 的基本语法
  11. Excel最强玩法!只用Excel就能做出「王者荣耀」战绩表
  12. NVIDIA GPU简史、命名规则及基础知识
  13. matlab图像取样和量化,数字图像基础之图像取样和量化
  14. 利用电脑学象棋的一点想法
  15. Kali 无线网卡无法连接到网络
  16. Help Hanzo LightOJ - 1197
  17. 用PS做法线,高光贴图的最简图文教程
  18. php免费问答源码,whatsns问答系统PHP免费源码 v4.1
  19. 什么是搜索引擎蜘蛛机器人?是如何工作的
  20. 英语面试最实用的五大技巧

热门文章

  1. 利用java开发一个猜数字幸运小游戏:游戏规则如下
  2. SAP归档操作(客户主数据)
  3. 在ROS使用自己安装的eigen时的cmake错误
  4. 如果一个文件的大小超过了一张磁盘的大小,你该如何存储?
  5. 小马哥---高仿苹果6sp 型号Q65 芯片6582 2016新版刷机拆机主板图与开机界面图
  6. 设计模式—备忘录模式
  7. 数据库锁表,杀死进程
  8. Android技术分享| 【自习室】自定义View代替通知动画(完)
  9. 朋友圈美食“小心机”拍摄技巧
  10. E3 1230V3和I5-4670K的比较