飘雪圣域(icekingdom)

题目描述

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 场暴风雪之后农业生产地域的个数。

样例输入

<span style="color:#333333">4 3
1 2
2 3
2 4
1 2
1 3
3 4</span>

样例输出

<span style="color:#333333">1
1
2</span>

提示

【输入输出样例 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。


solution

考场时一直从图的联通块来考虑,一直没想出来

这道题应该从加边来考虑

比如说询问区间(l,r)那么只有起点和终点在l,r里的边可以贡献

我们把边按较大的点排序,树状数组统计即可

#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#define maxn 200005
using namespace std;
int n,q,tree[maxn],ans[maxn];
struct node{int l,r,id;
}e[maxn],s[maxn];
bool cmp(node A,node B){return A.r<B.r;
}
void jia(int k,int v){for(int i=k;i<=n;i+=i&-i)tree[i]+=v;
}
int ask(int k){int sum=0;for(int i=k;i;i-=i&-i)sum+=tree[i];return sum;
}
int main(){cin>>n>>q;for(int i=1;i<n;i++){scanf("%d%d",&e[i].l,&e[i].r);if(e[i].l>e[i].r)swap(e[i].l,e[i].r);}sort(e+1,e+n,cmp);for(int i=1;i<=q;i++){scanf("%d%d",&s[i].l,&s[i].r);s[i].id=i;}sort(s+1,s+q+1,cmp);int now=1;for(int i=1;i<=q;i++){while(s[i].r>=e[now].r&&now<n){jia(e[now].l,1);now++;}int num=ask(s[i].r)-ask(s[i].l-1);ans[s[i].id]=s[i].r-s[i].l+1-num;}for(int i=1;i<=q;i++)printf("%d\n",ans[i]);return 0;
}

飘雪圣域(icekingdom)相关推荐

  1. #3985. 飘雪圣域(icekingdom)

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

  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. “真”5G标准出炉!不止是速度,这些难以置信的改变将彻底颠覆你的生活
  2. createjs开发h5游戏: 指尖大冒险
  3. Design Pattern - Decorator(C#)
  4. 理解JavaScript原型链
  5. 微软云服务再添新产品,这次来自两位华裔女科学家创办的AI公司
  6. 腐蚀rust研究台抽奖_延迟焦化装置的腐蚀风险分析
  7. Apache Shiro 使用手册(五)Shiro 配置说明
  8. aws rds监控慢sql_使用AWS Lambda函数自动启动/停止AWS RDS SQL Server
  9. CGI + FastCGI(PHP-FPM)联系与区别 【图解 + 注释】
  10. 【语音分析】基于matlab线性预测系数对比【含Matlab源码 557期】
  11. 最新聚合支付四方系统完整源码+修复大量BUG/新UI
  12. Android中TextToSpeech的使用
  13. 大文件编辑查看工具推荐:ultraedit、logviewer。文件太大notepad++等编辑工具无法打开解决办法
  14. 最全教程:微信小程序开发入门详解
  15. ThreadSanitizer检测工具-动态数据竞争检测技术
  16. 新政举市暖冬再现? 业内乐观情绪高涨
  17. 火车头采集ajax网址的技巧,使用post方法获得采集网址
  18. 小程序内部引导关注公众号实现方法
  19. 榆熙电商:带你了解一下拼多多先用后付的知识
  20. No provider available from registry 127.0.0.1:2181 for service com.ddbuy.ser 解决方法

热门文章

  1. 360php防护,phpyun注射绕过360防护
  2. 服务器配置asp+php,windows配置ASP\CGI\PHP全能服务器简明教程
  3. 乘着绘本的翅膀开启阅读之旅
  4. 使用JavaScript解决网页图片拉伸问题
  5. 浦东外服朋友阿R的时间线
  6. java uppercase方法_java 判断字符串首字符大写(uppercase或者capital)
  7. 使用JShaman进行JS代码加密时,保留字的作用
  8. 未来社会创业,一定是轻资产运营,小成本创业
  9. 我的大学时光:感谢那时候的努力与付出
  10. 台式计算机2017排行分析,最新台式电脑排行_2017联想台式电脑排行榜 联想台式电脑排行榜前10...