题目描述

“我有个愿望,我希望在灿烂千阳时遇见你。”

这是个有n个点的世界,有m条无向边连接着这n个点,但是不保证点之间能够互相到达。

“这个世界的夕阳,只在奇数长的简单路径的尽头。”一个神如是说。

于是我想知道对于一个点对(x,y),x到y之间的所有简单路径中是否存在长度为奇数的路径,只有这样,我才能找到存在有夕阳的路。

输入

第一行两个数n和m表示点的个数和边的条数。

接下来m行,每行两个数x,y表示x和y之间存在一条无向边。

接下来一行一个整数q表示询问的个数。

下面q行每行两个整数x,y表示一组询问,问x到y的所有简单路径中是否存在有长度为奇数的路径

输出

对于每组询问x,y,如果x与y之间存在一条长度为奇数的简单路径那么输出Yes否则输出No

样例输入


样例输出

No
Yes
Yes
Yes
No
Yes
Yes
Yes

数据范围

对于50%的数据,1≤n,m,q≤500

对于100%的数据,,1≤n,q,m≤100000

保证没有自环与重边。

题解:

若对原图解出生成树森林,那么询问点对(x,y)见是否有简单路径长度为奇数,可以看作求点对(x,y)是否有边在奇环上。

于是问题转化为判断是否有边在奇环中,这里解图的强联通分量,对于一个强联通分量,若其中有边在奇环上,那么分量中的所有边都在某个奇环上。

为了在分量中找到在奇环上的边,对图作tarjan算法,若点对(x,y)的深度的奇偶性相同,那么x和y的路径上的边都在奇环中。

#include<math.h>
#include<stdio.h>
#include<string.h>
#define buf 100001
#define MAXBUF 1<<9
#define dmin(a,b) ((a)<(b)?(a):(b))
inline void swp(int &x,int &y){
x^=y,
y^=x,
x^=y;
}
char B[MAXBUF],*S=B,*T=B;
inline char gt(){
if(S==T){
T=(S=B)+fread(B,,MAXBUF,stdin);
if(S==T)
return ;
}
return *S++;
}
inline void F(int &x){
x=;int c=gt(),f=;
for(;c<||c>;c=gt())
if(!(c^))
f=-;
for(;c>&&c<;c=gt())
x=(x<<)+(x<<)+c-;
x*=f;
}
struct Pointer{
int to;
Pointer *nxt;
}*fst[buf];
Pointer mem[buf<<],*tot=mem;
inline void link(int a,int b){
*++tot=(Pointer){b,fst[a]},fst[a]=tot;
*++tot=(Pointer){a,fst[b]},fst[b]=tot;
}
bool odd[buf];
int bin[],n,m,dfn[buf],dep[buf],fa[buf][],tim,s[buf],top,pb[buf],timer,low[buf],scn[buf],scx;
void tarjan(int x){
pb[++top]=x;
dfn[x]=low[x]=++timer;
for(int i=;i<=tim;i++)
fa[x][i]=fa[fa[x][i-]][i-];
for(Pointer *iter=fst[x];iter;iter=iter->nxt)
if(iter->to^fa[x][])
if(!dfn[iter->to])
fa[iter->to][]=x,
dep[iter->to]=dep[x]+,
tarjan(iter->to),
low[x]=dmin(low[x],low[iter->to]);
else
if(!scn[iter->to]){
low[x]=dmin(low[x],dfn[iter->to]);
if(!((dep[iter->to]&)^(dep[x]&)))
odd[x]=;
}
if(!(dfn[x]^low[x])){
bool f=;
int v=top;
for(;pb[v]^x;)
f|=odd[pb[v--]];
if(f)
for(v++;v<=top;v++)
s[pb[v]]++;
++scx;
do
v=pb[top--],
scn[v]=scx;
while(v^x);
}
}
void dfs(int x){
for(Pointer *iter=fst[x];iter;iter=iter->nxt)
if(!(fa[iter->to][]^x))
s[iter->to]+=s[x],
dfs(iter->to);
}
int lca(int x,int y){
if(dep[x]<dep[y])
swp(x,y);
for(int i=tim;i>=;i--)
if(dep[fa[x][i]]>=dep[y])
x=fa[x][i];
if(!(x^y))
return x;
for(int i=tim;i>=;i--)
if(fa[x][i]^fa[y][i])
x=fa[x][i],
y=fa[y][i];
return fa[x][];
}
int main(){
freopen("sunset.in","r",stdin),
freopen("sunset.out","w",stdout);
F(n),F(m);
tim=log(n)/log()+;
bin[]=;
for(int i=;i<=tim;i++)
bin[i]=bin[i-]<<;
for(int x,y;m;m--)
F(x),
F(y),
link(x,y);
for(int i=;i<=n;i++)
if(!dfn[i])
dep[i]=,
fa[i][]=i,
tarjan(i);
for(int i=;i<=n;i++)
if(!(fa[i][]^i))
dfs(i);
int q,x,y,t;
for(F(q);q;q--){
F(x),F(y);
if(fa[x][tim]^fa[y][tim])
puts("No");
else
t=lca(x,y),
puts(((dep[x]+dep[y]-(dep[t]<<))&
||s[x]+s[y]-(s[t]<<)>)?
"Yes":
"No");
}
fclose(stdin),
fclose(stdout);
}

NOIP模拟赛 夕阳的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  3. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  4. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  5. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  6. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  7. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

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

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

  9. CH Round #52 - Thinking Bear #1 (NOIP模拟赛)

    A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...

随机推荐

  1. SharePoint 2013 配置基于表单的身份认证

    前 言 这里简单介绍一下为SharePoint 2013 配置基于表单的身份认证,简单的说,就是用Net提供的工具创建数据库,然后配置SharePoint 管理中心.STS服务.Web应用程序的三处w ...

  2. 【转】SharePoint camel query查询 event 或者Calendar 日历列表的时候,怎么查询所有的重复发生的事件

    When you query a SharePoint calendar your results will contain: All non-recurring events The first e ...

  3. Ubuntu下安装Naginx, PHP5(及PHP-FPM),MySQL

    一:安装前做个简单的说明 二:安装MySQL 三:安装Nginx 四:安装PHP5 五:配置 nginx,以下是我本机的配置文件. 六:让MySQL支持PHP5 七:配置PHP-FPM 八:在/etc ...

  4. Android之登录时密码的保护

    在很多的Android项目中都需要用户登录.注册.这样的话在开发中做好保护用户密码的工作就显得尤为重要.这里我把自己的密码保护方法记录下来. 这是我建了一个保存密码的文件,以便于检查自己保存密码或者上 ...

  5. 操作系统开发系列—13.c.进程之中断重入

    现在又出现了另外一个的问题,在中断处理过程中是否应该允许下一个中断发生? 让我们修改一下代码,以便让系统可以在时钟中断的处理过程中接受下一个时钟中断.这听起来不是个很好的主意,但是可以借此来做个试验. ...

  6. 一次对MKMapView的性能优化

    一次对MKMapView的性能优化 前言 最近做的项目主要是LBS这块 主打成员定位功能 我们的UI设计是这样的 乍一看上去是挺好挺美观的 不同的人会显示不同的头像 可是当人扎堆的时候 问题就来了 当 ...

  7. 百度编辑器ueditor 异步加载时,初始化没办法赋值bug解决方法

    百度编辑器ueditor 异步加载时,初始化没办法赋值bug解决方法 金刚 前端 ueditor 初始化 因项目中使用了百度编辑器——ueditor.整体来说性能还不错. 发现问题 我在做一个编辑页面 ...

  8. Entity Framework 4.1 - Code First 指定外键名称

    Entity Framework 4.1 中,生成外键的方式有以下几种: 1-指定导航属性,会自动生成外键,命名规则为:“表名_主键名”2-默认情况下与导航属性的主键名称相同的字段会自动被标记为外键, ...

  9. fillStyle线性渐变

    废话小说,沾待马 <!DOCTYPE HTML> <head> <meta charset = "utf-8"> <title>ca ...

  10. 2014.1.23 Discuz论坛迁移+VPS配置手记

    虽说这也不是我第一次转移这个论坛了,但毕竟还是第一次自己配置VPS,写点东西记一下 一:关于VPS的配置 1.用TeamViewer连接服务器 这个VPS的IDC自己带有一个远程控制的页面,用浏览器打 ...