洛谷P3398 仓鼠找sugar [LCA]
仓鼠找sugar
题目描述
小仓鼠的和他的基(mei)友(zi)sugar住在地下洞穴中,每个节点的编号为1~n。地下洞穴是一个树形结构。这一天小仓鼠打算从从他的卧室(a)到餐厅(b),而他的基友同时要从他的卧室(c)到图书馆(d)。他们都会走最短路径。现在小仓鼠希望知道,有没有可能在某个地方,可以碰到他的基友?
小仓鼠那么弱,还要天天被zzq大爷虐,请你快来救救他吧!
输入输出格式
输入格式:
第一行两个正整数n和q,表示这棵树节点的个数和询问的个数。
接下来n-1行,每行两个正整数u和v,表示节点u到节点v之间有一条边。
接下来q行,每行四个正整数a、b、c和d,表示节点编号,也就是一次询问,其意义如上。
输出格式:
对于每个询问,如果有公共点,输出大写字母“Y”;否则输出“N”。
输入输出样例
- 5 5
- 2 5
- 4 2
- 1 3
- 1 4
- 5 1 5 1
- 2 2 1 4
- 4 1 3 4
- 3 1 1 5
- 3 5 1 4
- Y
- N
- Y
- Y
- Y
说明
__本题时限1s,内存限制128M,因新评测机速度较为接近NOIP评测机速度,请注意常数问题带来的影响。__
20%的数据 n<=200,q<=200
40%的数据 n<=2000,q<=2000
70%的数据 n<=50000,q<=50000
100%的数据 n<=100000,q<=100000
分析:
一道有点意思的题目。
首先我们需要知道这样一条性质,树上两条路径相交,则必定其中一条路径起点终点的$LCA$在另一条路径上。如果知道了这条性质就只需要求$LCA$就行了。(这里博主用树剖求的$LCA$)
Code:
- //It is made by HolseLee on 4th Nov 2018
- //Luogu.org P3398
- #include<bits/stdc++.h>
- using namespace std;
- const int N=1e5+;
- int n,m,dep[N],top[N],fa[N],siz[N],hson[N],head[N],cnte;
- struct Node { int to,nxt; }e[N<<];
- inline int read()
- {
- char ch=getchar(); int x=; bool flag=false;
- while( ch<'' || ch>'' ) {
- if( ch=='-' ) flag=true; ch=getchar(); }
- while( ch>='' && ch<='' ) {
- x=x*+ch-''; ch=getchar(); }
- return flag ? -x : x;
- }
- inline void add(int x,int y)
- {
- e[++cnte].to=y, e[cnte].nxt=head[x], head[x]=cnte;
- e[++cnte].to=x, e[cnte].nxt=head[y], head[y]=cnte;
- }
- void dfs1(int x,int las)
- {
- siz[x]=;
- for(int i=head[x],y; i; i=e[i].nxt) {
- y=e[i].to;
- if( y==las ) continue;
- dep[y]=dep[x]+, fa[y]=x;
- dfs1(y,x); siz[x]+=siz[y];
- if( siz[y]>siz[hson[x]] ) hson[x]=y;
- }
- }
- void dfs2(int x,int nowtop)
- {
- top[x]=nowtop;
- if( !hson[x] ) return;
- dfs2(hson[x],nowtop);
- for(int i=head[x],y; i; i=e[i].nxt) {
- y=e[i].to;
- if( y==fa[x] || y==hson[x] ) continue;
- dfs2(y,y);
- }
- }
- inline int LCA(int x,int y)
- {
- while( top[x]!=top[y] ) {
- if( dep[top[x]]<dep[top[y]] ) swap(x,y);
- x=fa[top[x]];
- }
- return dep[x]<dep[y] ? x : y;
- }
- inline bool check(int a,int b,int c,int d)
- {
- int lca1=LCA(a,b), lca2=LCA(c,d);
- if( dep[lca1]>=dep[lca2] ) {
- if( LCA(c,lca1)==lca1 ) return true;
- if( LCA(d,lca1)==lca1 ) return true;
- } else {
- if( LCA(a,lca2)==lca2 ) return true;
- if( LCA(b,lca2)==lca2 ) return true;
- }
- return false;
- }
- int main()
- {
- n=read(); m=read();
- for(int i=; i<n; ++i) add(read(),read());
- dep[]=; dfs1(,); dfs2(,);
- int a,b,c,d;
- for(int i=; i<=m; ++i) {
- a=read(), b=read(), c=read(), d=read();
- if( check(a,b,c,d) ) puts("Y");
- else puts("N");
- }
- return ;
- }
洛谷P3398 仓鼠找sugar [LCA]的更多相关文章
- 洛谷 P3398 仓鼠找sugar 解题报告
P3398 仓鼠找sugar 题目描述 小仓鼠的和他的基(mei)友(zi)sugar住在地下洞穴中,每个节点的编号为1~n.地下洞穴是一个树形结构.这一天小仓鼠打算从从他的卧室(a)到餐厅(b),而 ...
- 洛谷P3398 仓鼠找sugar
题目描述 小仓鼠的和他的基(mei)友(zi)sugar住在地下洞穴中,每个节点的编号为1~n.地下洞穴是一个树形结构.这一天小仓鼠打算从从他的卧室(a)到餐厅(b),而他的基友同时要从他的卧室(c) ...
- 洛谷——P3398 仓鼠找sugar
https://www.luogu.org/problem/show?pid=3398#sub 题目描述 小仓鼠的和他的基(mei)友(zi)sugar住在地下洞穴中,每个节点的编号为1~n.地下洞穴 ...
- 洛谷 P3398 仓鼠找sugar 题解
每日一题 day44 打卡 Analysis 首先有一个结论:先找 p1=(a,b),p2=(c,d) 的LCA的深度,在与(a,c),(a,d),(b,c),(b,d)中最深的LCA n的深度比较, ...
- 洛谷 [P3398] 仓鼠找sugar
树剖求LCA 我们可以发现,两条路径ab,cd相交,当且仅当 dep[lca(a,b)]>=dep[lca(c,d)]&(lca(lca(a,b),c)==lca(a,b)||lca(l ...
- 洛谷 P3398 仓鼠找sugar —— 树链剖分
题目:https://www.luogu.org/problemnew/show/P3398 树链剖分一下,路径就变成线段树上的几个区间: 两条路径相交就是线段树上有区间相交,所以在相应位置打个标记, ...
- 洛谷P3412 仓鼠找$Sugar\ II$题解(期望+统计论?)
洛谷P3412 仓鼠找\(Sugar\ II\)题解(期望+统计论?) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1327573 原题链接:洛谷P3412 ...
- 洛谷p3398仓鼠找suger题解
我现在爱死树链剖分了 题目 具体分析的话在洛谷blog里 这里只是想放一下改完之后的代码 多了一个son数组少了一个for 少了找size最大的儿子的for #include <cstdio&g ...
- 洛谷10月月赛Round.1| P3398 仓鼠找sugar[LCA]
题目描述 小仓鼠的和他的基(mei)友(zi)sugar住在地下洞穴中,每个节点的编号为1~n.地下洞穴是一个树形结构.这一天小仓鼠打算从从他的卧室(a)到餐厅(b),而他的基友同时要从他的卧室(c) ...
随机推荐
- aws上部署zabbix3.4
三台机器 10.0.0.149 AmazonLinux2.0 zabbix-server zabbix-agent 10.0.1.61 CentOS6.9 zabbix-agent 10.0.1.11 ...
- 1.Unix,Linux起源与编译原理
一.UNIX操作系统 作者:丹尼斯.里奇,肯.汤普逊 版权:贝尔实验室 时间:1971 特点:多用户,多任务(多进程),多CPU(多种CPU架构),高安全,高可靠,高性能,高稳定 应用:构 ...
- C# 编码规范、命名规则
1 规范目的 ……………………………………………………… 3 2 适用范围 ……………………………………………………… 3 3 代码注释 ……………………………………………………… 3 3.1 ...
- Asp.net 子web application的Session共享
需求提出: 网站: 父Web Application: http://www.test.com/ 子Web Application 1: http://www.test.com/child1 子Web ...
- 【配置】Spring Struts配置信息
- sql 跨服务器查询数据
方法一:用OPENDATASOURCE [SQL SERVER] 跨服务器查询 --1 打开 reconfigure reconfigure SELECT * FROM OPENDATASOURCE( ...
- Hibernate5总结
1. 明确Hibernate是一个实现了ORM思想的框架,它封装了JDBC,是程序员可以用对象编程思想来操作数据库. 2. 明确ORM(对象关系映射)是一种思想,JPA(Java Persistenc ...
- Heapify
Given an integer array, heapify it into a min-heap array. For a heap array A, A[0] is the root of he ...
- Android 7.0 新增功能和api
Android 7.0 Nougat 为用户和开发者引入多种新功能.本文重点介绍面向开发者的新功能. 请务必查阅 Android 7.0 行为变更以了解平台变更可能影响您的应用的领域. 要详细了解 A ...
- stylus项目知识点
1.在项目中,引入.sty文件的时候,用来下面方式 @import "~common/stylus/variable.styl" ~ 是stylus的写法,参考https://gi ...