这道题也算是厉害了,改了整整俩小时最后发现是深信的LCA打错了,悲伤啊!信仰崩塌了!

顺便复习LCA,给出模板

void init(){//p[i][j]表示i节点2^j的祖先
	int j;
	for(j=0;(1<<j)<=n;j++)
		pos(i,1,n)
			p[i][j]=-1;
	pos(i,1,n)
		p[i][0]=fa[i];
	for(j=1;(1<<j)<=n;j++)
		pos(i,1,n)
			if(p[i][j-1]!=-1)
				p[i][j]=p[p[i][j-1]][j-1];//i的2^j祖先即为2^(j-1)祖先的2^(j-1)祖先
}
int lca(int a,int b){
	int i;
	if(dep[a]<dep[b]) swap(a,b);//深度深的先爬
	for(i=0;(1<<i)<=dep[a];i++);
	i--;
	for(int j=i;j>=0;j--)
		if(dep[a]-(1<<j)>=dep[b])
			a=p[a][j];//爬到等高
	if(a==b) return a;//如果在一条链上,直接返回
	for(int j=i;j>=0;j--){
		if(p[a][j]!=-1&&p[a][j]!=p[b][j]){
			a=p[a][j];b=p[b][j];//两边一起爬,直到爬到LCA
		}
	}
	return fa[a];
}

这道题的题解是这样的:

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<queue>
#include<cmath>
#define pos(i,a,b) for(int i=(a);i<=(b);i++)
using namespace std;
#define N 101000
int n,m;
struct haha{
	int next,to;
}edge[N*2];
int head[N],cnt=1;
void add(int u,int v){
	edge[cnt].to=v;edge[cnt].next=head[u];head[u]=cnt++;
}
int dep[N],fa[N],size[N];
int p[N][22];
void dfs(int x){
	size[x]=1;
	for(int i=head[x];i;i=edge[i].next){
		int to=edge[i].to;
		if(fa[x]!=to){
			fa[to]=x;dep[to]=dep[x]+1;
			dfs(to);size[x]+=size[to];
		}
	}
}
void init(){//p[i][j]表示i节点2^j的祖先
	int j;
	for(j=0;(1<<j)<=n;j++)
		pos(i,1,n)
			p[i][j]=-1;
	pos(i,1,n)
		p[i][0]=fa[i];
	for(j=1;(1<<j)<=n;j++)
		pos(i,1,n)
			if(p[i][j-1]!=-1)
				p[i][j]=p[p[i][j-1]][j-1];//i的2^j祖先即为2^(j-1)祖先的2^(j-1)祖先
}
int lca(int a,int b){
	int i;
	if(dep[a]<dep[b]) swap(a,b);//深度深的先爬
	for(i=0;(1<<i)<=dep[a];i++);
	i--;
	for(int j=i;j>=0;j--)
		if(dep[a]-(1<<j)>=dep[b])
			a=p[a][j];//爬到等高
	if(a==b) return a;//如果在一条链上,直接返回
	for(int j=i;j>=0;j--){
		if(p[a][j]!=-1&&p[a][j]!=p[b][j]){
			a=p[a][j];b=p[b][j];//两边一起爬,直到爬到LCA
		}
	}
	return fa[a];
}
int get(int x,int anc,int num){
	int i;
	for(i=0;(1<<i)<=dep[x];i++);
	i--;
	for(int j=20;j>=0;j--)
		if(dep[x]-(1<<j)>=dep[anc]+num)
			x=p[x][j];
	return x;
}
int main(){
	//freopen("date.in","r",stdin);
	//freopen("date.out","w",stdout);
	scanf("%d",&n);
	pos(i,1,n-1){
		int x,y;scanf("%d%d",&x,&y);
		add(x,y);add(y,x);
	}
	dfs(2);//cout<<fa[2];
	init();
	scanf("%d",&m);//system("pause");
	pos(i,1,m){
		int x,y;scanf("%d%d",&x,&y);
		int anc=lca(x,y);
		int dis=dep[x]+dep[y]-2*dep[anc];//cout<<dis<<endl;
		if(dis%2==1){
			printf("0\n");continue;
		}
		if(x==y){
			printf("%d\n",n);continue;
		}
		if(dep[x]==dep[y]){
			int p1=get(x,anc,1),p2=get(y,anc,1);
			printf("%d\n",n-size[p1]-size[p2]);
			continue;
		}
		if(dep[x]<dep[y]) swap(x,y);
		int p1=get(x,x,-dis/2),p2=get(x,p1,1);
		printf("%d\n",size[p1]-size[p2]);
	}
	return 0;
}

[NOIP模拟赛]约会date LCA(顺便填坑)的更多相关文章

  1. CH Round #58 - OrzCC杯noip模拟赛day2

    A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...

  2. CH Round #55 - Streaming #6 (NOIP模拟赛day2)

    A.九九归一 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2355%20-%20Streaming%20%236%20(NOIP模拟赛day2)/九九归一 题 ...

  3. 10.16 NOIP模拟赛

    目录 2018.10.16 NOIP模拟赛 A 购物shop B 期望exp(DP 期望 按位计算) C 魔法迷宫maze(状压 暴力) 考试代码 C 2018.10.16 NOIP模拟赛 时间:2h ...

  4. NOIP模拟赛-2018.11.7

    NOIP模拟赛 如果用命令行编译程序可以发现没加头文件之类的错误. 如果用命令行编译程序可以发现没加头文件之类的错误. 如果用命令行编译程序可以发现没加头文件之类的错误. 编译之前另存一份,听说如果敲 ...

  5. NOIP模拟赛-2018.11.6

    NOIP模拟赛 今天想着反正高一高二都要考试,那么干脆跟着高二考吧,因为高二的比赛更有技术含量(我自己带的键盘放在这里). 今天考了一套英文题?发现阅读理解还是有一些困难的. T1:有$n$个点,$m ...

  6. NOI.AC NOIP模拟赛 第五场 游记

    NOI.AC NOIP模拟赛 第五场 游记 count 题目大意: 长度为\(n+1(n\le10^5)\)的序列\(A\),其中的每个数都是不大于\(n\)的正整数,且\(n\)以内每个正整数至少出 ...

  7. 【BZOJ 2957】楼房重建&&Codechef COT5 Count on a Treap&&【NOIP模拟赛】Weed 线段树的分治维护

    线段树是一种作用于静态区间上的数据结构,可以高效查询连续区间和单点,类似于一种静态的分治.他最迷人的地方在于“lazy标记”,对于lazy标记一般随我们从父区间进入子区间而下传,最终给到叶子节点,但还 ...

  8. 2016-06-19 NOIP模拟赛

          2016-06-19 NOIP模拟赛 by coolyangzc 共3道题目,时间3小时 题目名 高级打字机 不等数列 经营与开发 源文件 type.cpp/c/pas num.cpp/c ...

  9. NOIp模拟赛二十八

    (这是NOIp模拟赛?应该是NOI模拟赛不小心加了个p) 嗯,假装这是正经的NOIp模拟赛,从今天开始也写写题解吧(这几天被虐的惨惨) 今日情况:8+50+0=58 A题输出样例,B题正解写挂,C题不 ...

随机推荐

  1. 使用Ansible进行项目的自动部署(Tomcat、Weblogic)

    原文:https://github.com/x113773/testall/issues/4 问题:Weblogic/Tomcat 通过JAVA直接远程调用或者调用本地Shell还是通过Ansible ...

  2. 学编程担心自己英语不好吗?(IT软件开发常用英语词汇)

    发一份,我们导师的收集的常用词汇,与大家共享 欢迎加入Java学习交流裙六一六九五九四四四! S 欢迎加入Java学习交流裙 六一六  九五九  四四四!

  3. as 快捷键

    as  快捷键 Ctrl+G / Ctrl+Alt+Shift+G:查询变量或者函数或者类在哪里被使用或被调用,后者是前者的复杂表现,可以选择查询范围等. Alt+H:查找功能,全局查找 F4:查看类 ...

  4. AJAX请求小项目

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. Java程序设计---io流读取文件内容并将其逆值输出到控制台

    import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.File;import java.io.FileR ...

  6. 【原创】源码角度分析Android的消息机制系列(六)——Handler的工作原理

    ι 版权声明:本文为博主原创文章,未经博主允许不得转载. 先看Handler的定义: /** * A Handler allows you to send and process {@link Mes ...

  7. centos7 minimal版本下mysql的安装

    最近第一次尝在虚拟机上安装mysql,由于是centos7 minimal版本,很多安装包或命令必须自己添加,遇到很多问题. 首先是执行# yum install mysql-server 报错: 打 ...

  8. app 选项卡代码

    <div id="segmented" class="mui-segmented-control"> <a class="mui-c ...

  9. 我的学习之路_第二十五_javaScript

    Javascript 作用:可以对表单数据进行校验,可以对页面实现一些动态效果 定义: JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型. 它的解释器被称为 ...

  10. redis内存消耗详解

    Redis所有的数据都存在内存中,相对于廉价的硬盘,内存资源还是比较昂贵的,因此如何高效利用redis内存变得非常重要. 内存消耗分析 管理内存的原理和方法 内存优化技巧 一.内存消耗 理解redis ...