Description

题面

题目大意:有一个的网格图,给出其中的 \(n\) 个点,要你给这些点染蓝色或红色,满足对于每一行每一列都有红蓝数量的绝对值之差不超过1

Solution

首先建立二分图,点\((x,y)\)视作 \(x->y'\) 的一条边

问题转化为:给边染色,使得每一个点的两种颜色的数量之差不超过\(1\)

如果原图存在欧拉回路,那么沿着欧拉回路交替染色即可(因为一定是偶环)

但是实际上存在度数为奇数的点,不能够成欧拉回路,所以我们先把它变成欧拉回路

容易发现度数为奇数的点的数量是偶数,那么我们新加一些边,使得奇数点两两匹配连边,那么度数就变成了偶数

然后我们发现这样原图就不一定是二分图了,有可能存在奇环(只有起始点会矛盾)

我们先把度数为奇数的点遍历掉,如果没有被遍历到的就都是偶环了,黑白染色肯定符合要求,我们可以直接丢掉

实际上我们只需要从新加入的边开始找欧拉回路就行了,因为这条边实际上是废边

如何证明正确性?

因为矛盾的情况一定是起始点存在某种颜色多了\(1\),而废边正好把这个多了的给消除了,所以是合法的

注意:找欧拉回路时,走过的边就可以不走了,那么就可以从邻接表上直接删除,不然复杂度会出问题

#include<bits/stdc++.h>
using namespace std;
const int N=400400,M=2e5;
int n,head[N],nxt[N<<1],to[N<<1],num=1,in[N],q[N],top=0,tot;
bool vis[N],ans[N],v[N<<1];int id[N<<1];
inline void link(int x,int y,int ID)
{nxt[++num]=head[x];to[num]=y;head[x]=num;id[num]=ID;}
inline void dfs(int x){
vis[x]=1;
int i;
while(head[x]){
i=head[x];
head[x]=nxt[i];
if(v[i])continue;
v[i^1]=1,dfs(to[i]);
q[++top]=id[i];
}
}
int main(){
int x,y;
scanf("%d",&n);tot=M<<1;
for(int i=1;i<=n;i++){
scanf("%d%d",&x,&y);
link(x,y+M,i);link(y+M,x,i);
in[x]++;in[y+M]++;
}
static int lis[N],cnt=0;
for(int i=1;i<=tot;i++)if(in[i]&1)lis[++cnt]=i;
for(int i=1;i<=cnt;i+=2)link(lis[i],lis[i+1],0),link(lis[i+1],lis[i],0);
bool c=0;
for(int i=1;i<=cnt;i++){
if(!vis[lis[i]]){
dfs(lis[i]);c=0;
while(top){
c^=1;
if(q[top])ans[q[top]]=c;
q[top--]=0;
}
}
}
for(int i=1;i<=tot;i++){
if(!vis[i]){
dfs(i);c=0;
while(top){
c^=1;
if(q[top])ans[q[top]]=c;
q[top--]=0;
}
}
}
for(int i=1;i<=n;i++)printf("%c",ans[i]?'r':'b');
return 0;
}

Codeforces 547D Mike and Fish的更多相关文章

  1. CodeForces - 547D: Mike and Fish (转化为欧拉回路)(优化dfs稠密图)(定向问题)

    As everyone knows, bears love fish. But Mike is a strange bear; He hates fish! The even more strange ...

  2. Codeforces 547D - Mike and Fish(欧拉回路)

    Codeforces 题目传送门 & 洛谷题目传送门 首先考虑将题目中的条件转化为图论的语言.看到"行""列",我们很自然地想到二分图中行.列转点,点转 ...

  3. Codeforces.547D.Mike and Fish(思路 欧拉回路)

    题目链接 \(Description\) 给定平面上n个点,将这些点染成红or蓝色,要求每行.每列红色点与蓝色点数量的差的绝对值<=1.输出方案(保证有解). \(Solution\) 参考这 ...

  4. CodeForces 547D Mike and Fish 思维

    题意: 二维平面上给出\(n\)个点,然后对每个点进行染色:红色和蓝色,要求位于同一行或同一列的点中,红色点和蓝色点的个数相差不超过1 分析: 正解是求欧拉路径,在这篇博客中看到一个巧妙的思路: 对于 ...

  5. Codeforces 247D Mike and Fish

    Mike and Fish 我们可以把这个模型转换一下就变成有两类点,一类是X轴, 一类是Y轴, 每个点相当于对应的点之间建一条边, 如果这条边变红两点同时+1, 变蓝两点同时-1. 我们能发现这个图 ...

  6. 547D Mike and Fish

    传送门 分析 见正睿10.3笔记 代码 #include<iostream> #include<cstdio> #include<cstring> #include ...

  7. CF 547 D. Mike and Fish

    D. Mike and Fish http://codeforces.com/contest/547/problem/D 题意: 给定平面上n个点,将这些点染成红或者蓝色,要求每行.每列红色点与蓝色点 ...

  8. hdu4135-Co-prime & Codeforces 547C Mike and Foam (容斥原理)

    hdu4135 求[L,R]范围内与N互质的数的个数. 分别求[1,L]和[1,R]和n互质的个数,求差. 利用容斥原理求解. 二进制枚举每一种质数的组合,奇加偶减. #include <bit ...

  9. codeforces 547E Mike and Friends

    codeforces 547E Mike and Friends 题意 题解 代码 #include<bits/stdc++.h> using namespace std; #define ...

随机推荐

  1. vim的配置

    修改根目录下.vimrc文件: 1.设定解码,支持中文 set fileencodings=utf-8,ucs-born,gb18030,gbk,gb2312,cp936 set termencodi ...

  2. 本地通知UILocalNotification

    1.增加一个本地推送 //设置20秒之后  ]; //chuagjian一个本地推送 UILocalNotification *noti = [[[UILocalNotification alloc] ...

  3. Beta冲刺Day5

    项目进展 李明皇 今天解决的进度 服务器端还未完善,所以无法进行联动调试.对页面样式和逻辑进行优化 明天安排 前后端联动调试 林翔 今天解决的进度 完成维护登录态,实现图片上传,微信开发工具上传图片不 ...

  4. 关于mule中Spring使用中的一个问题

    在mule中连接数据库时,大家通常喜欢使用spring的数据库连接以及bean的配置,但是在使用时会出现一些问题,即bean无法找到,这些,就是需要把bean的id属性改成name属性:可能是因为mu ...

  5. DML数据操作语言之增加,删除,更新

    1.数据的增加 数据的增加要用到insert语句  ,基本格式是: insert into <表名> (列名1,列名2,列名3,......) values (值1,值2,值3,..... ...

  6. PHP之this和self

    self在对象中自己调用自己使用 $this在实例化后使用$this方法 在访问PHP类中的成员变量或方法时,如果被引用的变量或者方法被声明成const(定义常量)或者static(声明静态),那么就 ...

  7. Python之旅.第三章.函数3.28

    一.命名关键字参数: 什么是命名关键字参数?格式:在*后面参数都是命名关键字参数特点:1 必须被传值1 约束函数的调用者必须按照key=value的形式传值2 约束函数的调用者必须用我们指定的key名 ...

  8. Javascript 装饰器极速指南

    pablo.png Decorators 是ES7中添加的JavaScript新特性.熟悉Typescript的同学应该更早的接触到这个特性,TypeScript早些时候已经支持Decorators的 ...

  9. WPF 自定义DataGrid控件样式

    内容转自https://www.cnblogs.com/xiaogangqq123/archive/2012/05/07/2487166.html 一.DataGrid基本样式(一) 小刚已经把Dat ...

  10. wordpress怎么禁止文章复制

    登陆你的网站后台--点击菜单栏的"外观"--点击"编辑"--在右侧,找到footer.php,打开它--在</body>之前加入以下代码: 1.禁止 ...