BZOJ 3351: [ioi2009]Regions
对于一个询问(x,y)对y出现次数分类,若<=lim,在儿子处统计答案,若>lim则y的种类肯定<lim,在祖先处统计(仿佛要去重?但是没去重也过了,那个时限仿佛怎么做都能过)
#include<cstdio>
#include<algorithm>
#include<vector>
#define pr pair<int,int>
#define mp make_pair
#define fr first
#define sc second
using namespace std;
int cnt,last[1000005],Sum[1000005],c[1000005],sz[1000005];
long long ANS[1000005];
vector<pr> vec1[1000005],vec2[1000005];
struct node{
int to,next;
}e[1000005];
void add(int a,int b){
e[++cnt].to=b;
e[cnt].next=last[a];
last[a]=cnt;
}
void solve1(int x,int fa){
for (int i=0; i<(int)vec1[c[x]].size(); i++){
pr q=vec1[c[x]][i];
ANS[q.fr]+=Sum[q.sc];
}
Sum[c[x]]++;
for (int i=last[x]; i; i=e[i].next){
int V=e[i].to;
if (V==fa) continue;
solve1(V,x);
}
Sum[c[x]]--;
}
void solve2(int x,int fa){
Sum[c[x]]++;
for (int i=0; i<(int)vec2[c[x]].size(); i++){
pr q=vec2[c[x]][i];
ANS[q.fr]-=Sum[q.sc];
}
for (int i=last[x]; i; i=e[i].next){
int V=e[i].to;
if (V==fa) continue;
solve2(V,x);
}
for (int i=0; i<(int)vec2[c[x]].size(); i++){
pr q=vec2[c[x]][i];
ANS[q.fr]+=Sum[q.sc];
}
}
int main(){
int n,R,q;
scanf("%d%d%d",&n,&R,&q);
scanf("%d",&c[1]);
sz[c[1]]++;
int lim=500;
for (int i=2; i<=n; i++){
int x;
scanf("%d%d",&x,&c[i]);
sz[c[i]]++;
add(x,i);
add(i,x);
}
for (int i=1; i<=q; i++){
int X,Y;
scanf("%d%d",&X,&Y);
if (sz[Y]<=lim) vec1[Y].push_back(mp(i,X));
else vec2[X].push_back(mp(i,Y));
}
solve1(1,0);
solve2(1,0);
for (int i=1; i<=q; i++) printf("%lld\n",ANS[i]);
return 0;
}
BZOJ 3351: [ioi2009]Regions的更多相关文章
- BZOJ.3351.[IOI2009]Regions(根号分治 差分)
		
BZOJ 表示非常爽2333 \(Description\) 给定一棵\(n\)个点的树,每个点有一个属性\(1\leq r_i\leq R\). \(Q\)次询问,每次询问给定\(r1,r2\),求 ...
 - bzoj3351:[ioi2009]Regions
		
思路:首先如果颜色相同直接利用以前的答案即可,可以离线排序或是在线hash,然后考虑怎么快速统计答案. 首先如果点a是点b的祖先,那么一定有点b在以点a为根的子树的dfs序区间内的,于是先搞出dfs序 ...
 - BZOJ3351: [ioi2009]Regions(根号分治)
		
题意 题目链接 Sol 很神仙的题 我们考虑询问(a, b)(a是b的祖先),直接对b根号分治 如果b的出现次数\(< \sqrt{n}\),我们可以直接对每个b记录下与它有关的询问,这样每个询 ...
 - 【dfs序】【二分】【主席树】【分块】bzoj3351 [ioi2009]Regions
		
http://dzy493941464.sinaapp.com/archives/96 那个SIZE貌似必须设成R*R/Q?不知为啥,自己算的不是这个的说. 本机AC,线上TLE. #include& ...
 - bzoj AC倒序
		
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
 - BZOJ 2127: happiness [最小割]
		
2127: happiness Time Limit: 51 Sec Memory Limit: 259 MBSubmit: 1815 Solved: 878[Submit][Status][Di ...
 - [LeetCode] Surrounded Regions 包围区域
		
Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'. A region is captured ...
 - BZOJ 3275: Number
		
3275: Number Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 874 Solved: 371[Submit][Status][Discus ...
 - BZOJ 2879: [Noi2012]美食节
		
2879: [Noi2012]美食节 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1834 Solved: 969[Submit][Status] ...
 
随机推荐
- Java浏览器下载文件为excel(springMVC方式)
			
action中的方法 /** * Excel文件下载处理 * @return */ @RequestMapping("/downloanExcel") public ModelAn ...
 - NHibernate中创建User类报错问题
			
前两天刚开始学习NHibernate架构,照着前辈的例子打了一遍运行之后没问题,然后自己创建了一个User的Model发现一运行就报User附近有错误,然后就检查,类写的没错用了virtual,Use ...
 - JAVA代码之斗地主发牌
			
理解很好理解,关键是思路 按照斗地主的规则,完成洗牌发牌的动作: 具体规则: 1. 组装54张扑克牌 2. 将54张牌顺序打乱 3. 三个玩家参与游戏,三人交替摸牌,每人17张牌,最后三张留作底牌. ...
 - Hello World另类写法
			
#include<iostream> #define _ using namespace std; #define __ int main() #define ___ { #define ...
 - Android--View事件传递
			
Android--View事件传递 View事件传递首先要明白以下要素: 事件就是MotionEvent.该对象包含了传递的事件中的所有信息 事件的来源是Window(即PhoneWindow),包含 ...
 - freebsd新添加磁盘
			
1.添加硬盘 2.查看现在的硬盘 3.执行sysinstall命令 4. 5. 6.按下enter键 7.A,C,Q 8. 9. 10.C,Q 11.newfs /dev/ad0 12.cd / &a ...
 - SharePoint 2013 安装配置(2)
			
上一篇中,我们已经安装了Windows Server 2012 R2.现在第二部分,如何在Windows Server 2012 R2中安装Active Directory域控制器.请按照以下步骤. ...
 - python之删除指定目录指定日期下的日志文件
			
#=======================================================================================20190521以下脚本 ...
 - MongoDB远程定时备份与还原
			
全手打原创,转载请标明出处:https://www.cnblogs.com/dreamsqin/p/10885165.html,多谢~=.= 备份命令mongodump脚本语法及各项参数含义 mong ...
 - Integer的一个小问题
			
看面试题的时候看到这道题: public class Demo { public static void main(String[] args) { Integer i1 = 128; Integer ...