题目描述

给定一张 \(n\) 个点 \(m\) 条边的无向图,现在想要把这张图定向。

有 \(p\) 个限制条件,每个条件形如 \((xi,yi)\) ,表示在新的有向图当中,\(x_i\) 要能够沿着一些边走到 \(y_i\) ​​。

现在请你求出,每条边的方向是否能够唯一确定。同时请给出这些能够唯一确定的边的方向。

输入格式

第一行两个空格隔开的正整数 \(n,m\) 。

接下来 \(m\) 行,每行两个空格隔开的正整数 \(a_i,b_i\) ,表示 \(a_i,b_i\) 之间有一条边。

接下来一行一个整数 \(p\),表示限制条件的个数。

接下来 \(p\) 行,每行两个空格隔开的正整数 \(x_i,y_i\),描述一个 \((x_i,y_i)\) 的限制条件。

输出格式

输出一行一个长度为 \(m\) 的字符串,表示每条边的答案:

  • 若第 \(i\) 条边必须得要是 \(a_i\)​​ 指向 \(b_i\) 的,那么这个字符串的第 \(i\) 个字符应当为 R

  • 若第 \(i\) 条边必须得要是 \(b_i\) 指向 \(a_i\) 的,那么这个字符串的第 \(i\) 个字符应当为 L

  • 否则,若第 \(i\) 条边的方向无法唯一确定,那么这个字符串的第 \(i\) 个字符应当为 B

样例

样例输入

5 6
1 2
1 2
4 3
2 3
1 3
5 1
2
4 5
1 3

样例输出

BBRBBL

数据范围与提示

对于所有测试点,有 \(1\le n,m,p\le 100\ 000;1\le a_i,b_i,x_i,y_i\le n\) 。

  • 子任务 1(\(30\%\)):有 \(n,m\le 1000;p\le 100\) ;

  • 子任务 2(\(30\%\)):有 \(p\le 100\) ;

  • 子任务 3(\(40\%\)):无特殊限制。

题解

在同一个点双内的显然不能完全确定

所以先Tarjan找点双并缩点

对于剩下的点与询问,就是在一棵树上了,随便搞一搞就好了

我是用的一种奇怪的方法

对于一个点,它的权值记录了它和它的父亲之间的边的方向

对于一个询问,找到询问中两个点的LCA,然后在两个点都打上LCA的标记,代表它们到LCA的这段路径上的所有边的方向全部为某个方向

由于题目保证无冲突,所以是不会有一条边会被赋值两次的

所有标记打完后,一遍dfs处理完所有标记就好了

#include<bits/stdc++.h>
#define ui unsigned int
#define ll long long
#define db double
#define ld long double
#define ull unsigned long long
const int MAXN=100000+10,inf=0x3f3f3f3f;
int n,m,q,e=1,beg[MAXN],nex[MAXN<<1],to[MAXN<<1],DFN[MAXN],LOW[MAXN],Visit_Num,bridge[MAXN<<1],cnt,bel[MAXN],qto[MAXN<<1],qnex[MAXN<<1],qbeg[MAXN],Jie[MAXN][21],up[MAXN],dep[MAXN],qe,mk[MAXN],ps[MAXN],nt;
struct node{
int u,v;
};
node side[MAXN];
template<typename T> inline void read(T &x)
{
T data=0,w=1;
char ch=0;
while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();
if(ch=='-')w=-1,ch=getchar();
while(ch>='0'&&ch<='9')data=((T)data<<3)+((T)data<<1)+(ch^'0'),ch=getchar();
x=data*w;
}
template<typename T> inline void write(T x,char ch='\0')
{
if(x<0)putchar('-'),x=-x;
if(x>9)write(x/10);
putchar(x%10+'0');
if(ch!='\0')putchar(ch);
}
template<typename T> inline void chkmin(T &x,T y){x=(y<x?y:x);}
template<typename T> inline void chkmax(T &x,T y){x=(y>x?y:x);}
template<typename T> inline T min(T x,T y){return x<y?x:y;}
template<typename T> inline T max(T x,T y){return x>y?x:y;}
inline void insert(int x,int y)
{
to[++e]=y;
nex[e]=beg[x];
beg[x]=e;
}
inline void qinsert(int x,int y)
{
qto[++qe]=y;
qnex[qe]=qbeg[x];
qbeg[x]=qe;
}
inline void Tarjan(int x,int f)
{
DFN[x]=LOW[x]=++Visit_Num;ps[x]=nt;
for(register int i=beg[x];i;i=nex[i])
if(!DFN[to[i]])
{
Tarjan(to[i],x);
chkmin(LOW[x],LOW[to[i]]);
if(LOW[to[i]]>DFN[x])bridge[i]=bridge[i^1]=1;
}
else if(DFN[to[i]]<DFN[x]&&to[i]!=f)chkmin(LOW[x],DFN[to[i]]);
}
inline void dfs(int x)
{
DFN[x]=1;bel[x]=cnt;
for(register int i=beg[x];i;i=nex[i])
if(bridge[i])continue;
else if(!DFN[to[i]])dfs(to[i]);
}
inline void idfs(int x,int f)
{
Jie[x][0]=f;dep[x]=dep[f]+1;
for(register int i=qbeg[x];i;i=qnex[i])
if(qto[i]==f)continue;
else idfs(qto[i],x);
}
inline void init()
{
for(register int j=1;j<=19;++j)
for(register int i=1;i<=cnt;++i)Jie[i][j]=Jie[Jie[i][j-1]][j-1];
}
inline int LCA(int u,int v)
{
if(dep[u]<dep[v])std::swap(u,v);
if(dep[u]>dep[v])
for(register int i=19;i>=0;--i)
if(dep[Jie[u][i]]>=dep[v])u=Jie[u][i];
if(u==v)return u;
for(register int i=19;i>=0;--i)
if(Jie[u][i]!=Jie[v][i])u=Jie[u][i],v=Jie[v][i];
return Jie[u][0];
}
inline void edfs(int x,int f)
{
for(register int i=qbeg[x];i;i=qnex[i])
if(qto[i]!=f)edfs(qto[i],x),chkmin(up[x],up[qto[i]]);
if(up[x]<dep[f])mk[f]=mk[x];
}
int main()
{
read(n);read(m);
for(register int i=1;i<=m;++i)
{
int u,v;read(u);read(v);
insert(u,v);insert(v,u);
side[i]=(node){u,v};
}
for(register int i=1;i<=n;++i)
if(!DFN[i])++nt,Tarjan(i,0);
memset(DFN,0,sizeof(DFN));
for(register int i=1;i<=n;++i)
if(!DFN[i])++cnt,dfs(i);
for(register int i=1,u,v;i<=m;++i)
if((u=bel[side[i].u])!=(v=bel[side[i].v]))qinsert(u,v),qinsert(v,u);
for(register int i=1;i<=cnt;++i)
if(!dep[i])idfs(i,0);
init();
memset(up,inf,sizeof(up));
read(q);
while(q--)
{
int x,y,lca;read(x);read(y);
if(bel[x]==bel[y]||ps[x]!=ps[y])continue;
x=bel[x],y=bel[y];lca=LCA(x,y);
if(x!=lca)chkmin(up[x],dep[lca]),mk[x]=-1;
if(y!=lca)chkmin(up[y],dep[lca]),mk[y]=1;
}
edfs(1,0);
for(register int i=1,u,v;i<=m;++i)
{
u=side[i].u,v=side[i].v;
if(bel[u]==bel[v])putchar('B');
else
{
u=bel[u],v=bel[v];
if(dep[u]>dep[v])
{
if(mk[u]==-1)putchar('R');
else if(mk[u]==1)putchar('L');
else putchar('B');
}
else
{
if(mk[v]==-1)putchar('L');
else if(mk[v]==1)putchar('R');
else putchar('B');
}
}
}
puts("");
return 0;
}

【刷题】LOJ 2480 「CEOI2017」One-Way Streets的更多相关文章

  1. @loj - 2480@ 「CEOI2017」One-Way Streets

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定一张 n 个点 m 条边的无向图,现在想要把这张图定向. 有 ...

  2. loj#2483. 「CEOI2017」Building Bridges 斜率优化 cdq分治

    loj#2483. 「CEOI2017」Building Bridges 链接 https://loj.ac/problem/2483 思路 \[f[i]=f[j]+(h[i]-h[j])^2+(su ...

  3. loj#2483. 「CEOI2017」Building Bridges(dp cdq 凸包)

    题意 题目链接 Sol \[f[i], f[j] + (h[i] - h[j])^2 + (w[i - 1] - w[j]))\] 然后直接套路斜率优化,发现\(k, x\)都不单调 写个cdq就过了 ...

  4. 【动态规划】loj#2485. 「CEOI2017」Chase

    有意思的可做dp题:细节有点多,值得多想想 题目描述 在逃亡者的面前有一个迷宫,这个迷宫由 nnn 个房间和 n−1n-1n−1 条双向走廊构成,每条走廊会链接不同的两个房间,所有的房间都可以通过走廊 ...

  5. @loj - 2483@「CEOI2017」Building Bridges

    目录 @desription@ @solution@ @accepted code@ @details@ @another solution@ @another code@ @desription@ ...

  6. Loj 3058. 「HNOI2019」白兔之舞

    Loj 3058. 「HNOI2019」白兔之舞 题目描述 有一张顶点数为 \((L+1)\times n\) 的有向图.这张图的每个顶点由一个二元组 \((u,v)\) 表示 \((0\le u\l ...

  7. LOJ #6436. 「PKUSC2018」神仙的游戏(字符串+NTT)

    题面 LOJ #6436. 「PKUSC2018」神仙的游戏 题解 参考 yyb 的口中的长郡最强选手 租酥雨大佬的博客 ... 一开始以为 通配符匹配 就是类似于 BZOJ 4259: 残缺的字符串 ...

  8. LOJ #6435. 「PKUSC2018」星际穿越(倍增)

    题面 LOJ#6435. 「PKUSC2018」星际穿越 题解 参考了 这位大佬的博客 这道题好恶心啊qwq~~ 首先一定要认真阅读题目 !! 注意 \(l_i<r_i<x_i\) 这个条 ...

  9. LOJ #6432. 「PKUSC2018」真实排名(组合数)

    题面 LOJ #6432. 「PKUSC2018」真实排名 注意排名的定义 , 分数不小于他的选手数量 !!! 题解 有点坑的细节题 ... 思路很简单 , 把每个数分两种情况讨论一下了 . 假设它为 ...

随机推荐

  1. python通讯录系统

    ---恢复内容开始--- 对于一般的通讯录系统,主要有两个参数:姓名和电话号码,所以可以利用python编程里面的字典来进行建立之间的所属关系, 可以利用以下代码简单实现: print('|--- 欢 ...

  2. TPO-22 C2 Revise a music history paper

    第 1 段 1.Listen to part of a conversation between a student and his music history professor. :听一段学生和音 ...

  3. CocoStuff—基于Deeplab训练数据的标定工具【四、用该工具标定个人数据】

    一.说明 本文为系列博客第四篇,主要讲述笔者在正式使用该工具使用自定义标签标注自己的图片的过程. 二.数据整理 相信大家已经在 *占坑

  4. 【Docker】第四篇 Docker仓库管理

    一.仓库概述 仓库(Repository):Docker仓库主要用于镜像的存储,它是镜像分发.部署的关键.仓库分为公共仓库和私有仓库. 注册服务器(Registry)和仓库区别:注册服务器上往往存放着 ...

  5. 7.openldap使用ssl加密认证

    作者:yaoyao 1.服务器端部署 1.自建CA中心 1.CA中心生成自身私钥 #cd /etc/pki/CA #(umask 077; openssl genrsa -out private/ca ...

  6. iOS 静态库 与 demo 联合调试

    在修复bug或者开发静态库需要调试,这个时候需要把工程中的.framework和资源bundle文件都替换为静态库原工程文件 首先需要确保静态库工程文件没有打开,Xcode不允许在两个地方同时打开同一 ...

  7. JavaWeb项目通过调用cmd实现备份数据库的功能

    1.别急着上车,先测试一下能否成功调用cmd,可以尝试通过cmd命令打开计算器,代码如下:     2.能成功打开计算器后,证明调用cmd的方法是没错的,现在把cmd命令字符串改成我们备份数据库的 命 ...

  8. Ubuntu下开启mysql远程访问

    1. 开启数据库3306端口 首先,使用如下指令查看3306端口是否对外开放. netstat -an | grep 3306 tcp 0 0 127.0.0.1:3306 0.0.0.0:* LIS ...

  9. “私人助手”Beta版使用说明

    私人助手(Beta)版使用说明 私人助手这款软件是通过添加事件提醒功能,让用户能在正确的时间做正确的事情,使得工作变得更有效率,而这款软件的特色在于提醒模式的添加,用户可以通过震动.铃声提醒,我们的特 ...

  10. “吃神么,买神么”的第三个Sprint冲刺总结

    第三阶段Spring的目标以及完成情况: 时间:6.16——6.26(10天) 目标:第三阶段主要是前台设计的修改完善,以及数据库成功连接,完成小部分功能 情况:前台界面完善,完成小部分功能(发布功能 ...