转化欧拉回路(难题)-UESTC-1957励志的猴子
励志的猴子
Time Limit: 1000 MS Memory Limit: 256 MB

上图是2013南京亚青会吉祥物圆圆。自从它诞生以来,它就被吐槽为最丑吉祥物。即使如此,它仍然坚强的活着,并且……它还学会了人类的坐标系、画画和数学,成为了猴界的全才。看到它这么努力,你还有理由不努力吗!
虽然如此努力,圆圆受限于猴子的脑容量,还是差了一点——它只能掌握一维坐标系,画画只能分辨两种颜色,数学上只会不等式,只能认识整数。这一天,圆圆很无聊,于是它拿起一维坐标纸,想在纸上画n条线段,第i条线段从坐标轴的xi延伸到yi(包括端点)。
励志的圆圆想要展示一下自己的智商,它用红蓝彩笔画下这n条线段,并且希望对于坐标轴上任意一个点,经过它的红线和蓝线数量的绝对值之差小于等于1.如果某个点是线段的端点,则这条线段也算作经过该点。
不过这时,圆圆发现自己的算数能力还是有点差,于是它找到了你,希望你确定每条线段的颜色,来满足它的奇思妙想。
Input
第一行一个整数n(1 ≤ n ≤ 100000), 表示圆圆画的线段的数量。
接下来n行,每行两个整数x,y( 0≤ x ≤ y ≤ 109109 ),表示一条线段从x延伸到y。
Output
输出n个数,用空格隔开,如果第i条线段是蓝色,则输出0,否则输出1.
如果有多组解,输出一组即可。
如果找不到答案,输出一个数-1.
Sample input and output
| Sample Input | Sample Output |
|---|---|
2 |
0 1 |
6 |
0 1 1 0 0 1 |
Hint
样例1: 第一条线段是蓝色,第二条线段是红色。
两组样例都可能有其他正确答案。
Source
X1 X2 ... Xk Xk+1
若将一个区间涂色,则所有包含这个区间的线段都要被涂色。
把这些区间看做图的节点,把线段看做图的边。
例如:对于一条包含区间{Xi, Xi+1, ..., Xj-1, Xj} 的线段,可以视为点i连向点j+1的一条无向边。这样,就组成了多个连通图。
对于每个连通图,我们需要把这些边按相同的方法涂色,就能解决问题。
那么,图中所有边组成的一条路径构成了一条欧拉回路。
代码:
using namespace std;
const int maxn=1e6;
const int maxn1=3e5;
struct part{
int v,id;
} ee[maxn];
struct part1{
int to,net;
} e[maxn];
int b[maxn],c[maxn],d[maxn],vis[maxn],flag[maxn],cnt,n,k,len;
int a[maxn],v[maxn],g[maxn1],head[maxn1],st[maxn1],du[maxn1],emp[maxn1],top,s[maxn1],f[maxn1];
bool cmp(part a,part b)
{
return a.v<b.v;
}
void addedge(int x,int y)
{
v[cnt]=0;
e[cnt].to=y;
e[cnt].net=st[x];
st[x]=cnt++;
}
void dfs(int x)
{
if(emp[x]==1) return ;
top++;
s[top]=x;
int ii=st[x];
while (ii!=-1&&v[ii]) ii=e[ii].net;
st[x]=ii;
if(ii==-1)
{
emp[x]=1;
return ;
}
if(ii!=-1)
{
v[ii]=1;
st[x]=e[ii].net;
if (st[x]==-1) emp[x]=1;
int p=e[ii].to;
int jj=ii^1;
v[jj]=1;
dfs(p);
}
}
void fluey(int x)
{
top=0;
s[top]=x;
while(top>=0)
{
if (emp[s[top]]==1)
{
len+=1;
f[len]=s[top];
flag[s[top]]=1;
top--;
}
else
{
top--;
dfs(s[top+1]);
}
}
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cin>>n;
int temp=0,x,y;
for(int i=1;i<=n;i++)
{
cin>>x>>y;
temp+=1;
ee[temp].v=x;
ee[temp].id=i;
temp+=1;
ee[temp].v=y+1;
ee[temp].id=i+n;
}
sort(ee+1,ee+1+2*n,cmp);
for(int i=1;i<=2*n;i++) c[ee[i].id]=i;
d[1]=ee[1].v;
b[1]=1;
k=1;
for(int i=2;i<=2*n;i++)
{
if(ee[i].v==d[k]) { b[i]=k; continue; }
else { k++; d[k]=ee[i].v; b[i]=k; }
cnt=0;
for(int i=1;i<=n*2;i++) st[i]=-1;
for(int i=1;i<=n;i++)
{
addedge(b[c[i]],b[c[i+n]]);
addedge(b[c[i+n]],b[c[i]]);
du[b[c[i]]]++;
du[b[c[i+n]]]++;
v[i-1]=0;
v[i+n-1]=0;
}
temp=0;
for(int i=1;i<=2*n;i++)
if(du[i]&1) a[++temp]=i;
sort(a+1,a+1+temp);
for(int i=1;i<=temp;i++)
if(i & 1)
{
addedge(a[i],a[i+1]);
addedge(a[i+1],a[i]);
du[a[i]]+=1;
du[a[i+1]]+=1;
}
for(int i=1;i<=n*2;i++)
{
if(du[i]>0) emp[i]=0;
else emp[i]=1;
}
for(int i=1;i<=2*n;i++) head[i]=st[i];
for(int j=1;j<=2*n;j++)
{
if(!flag[j] && du[j]>0)
{
len=0;
fluey(j);
memset(vis,0,sizeof vis);
for(int i=1;i<=len-1;i++)
{
x=f[i]; y=f[i+1];
int ii=head[x];
while(ii!=-1)
{
if(e[ii].to==y && vis[ii]==0) break;
ii=e[ii].net;
}
if(x<y) g[ii/2+1]=1;
else g[ii/2+1]=0;
vis[ii]=1;
vis[ii^1]=1;
}
}
}
for(int i=1;i<=n;i++) i==n? cout<<g[i]<<endl : cout<<g[i]<<" ";
return 0;
}
转化欧拉回路(难题)-UESTC-1957励志的猴子的更多相关文章
- 省时省心DTM,广告转化无难题
内容来源:华为开发者大会2021 HMS Core 6 App Services技术论坛,主题演讲<华为分析服务,助您打造数智化运营闭环方案>. 演讲嘉宾:华为消费者云服务 分析产品总监 ...
- UVa 12118 检查员的难题(dfs+欧拉回路)
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- php猴子称王或者约瑟夫难题
问题描述: 一群猴子排成一圈,按1,2,...,n依次编号.然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去...,如此不停的进行下去,直到最后只剩下一只猴子为 ...
- 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 ...
- UVA 10054 The Necklace 转化成欧拉回路
题意比较简单,给你n个项链碎片,每个碎片的两半各有一种颜色,最后要把这n个碎片串成一个项链,要求就是相邻碎片必须是同种颜色挨着. 看了下碎片总共有1000个,颜色有50种,瞬间觉得普通方法是无法在可控 ...
- UVA - 12118 Inspector's Dilemma(检查员的难题)(欧拉回路)
题意:有一个n个点的无向完全图,找一条最短路(起点终点任意),使得该道路经过E条指定的边. 分析: 1.因为要使走过的路最短,所以每个指定的边最好只走一遍,所以是欧拉道路. 2.若当前连通的道路不是欧 ...
- POJ 1637 混合图的欧拉回路判定
题意:一张混合图,判断是否存在欧拉回路. 分析参考: 混合图(既有有向边又有无向边的图)中欧拉环.欧拉路径的判定需要借助网络流! (1)欧拉环的判定:一开始当然是判断原图的基图是否连通,若不连通则一定 ...
- LightOJ1086 Jogging Trails(欧拉回路+中国邮递员问题+SPFA)
题目求从某点出发回到该点经过所有边至少一次的最短行程. 这个问题我在<图论算法理论.实现及应用>中看过,是一个经典的问题——中国邮递员问题(CPP, chinese postman pro ...
- nyist 673 悟空的难题
http://acm.nyist.net/JudgeOnline/problem.php?pid=673 悟空的难题 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 ...
随机推荐
- PHP 在 Laravel 中动态隐藏 API 字段
我最近在 Laravel Brasil 社区看到一个问题,结果比看起来更有趣.想象一下你有一个 UsersResource 用下面的实现: <?php namespace App\Http\Re ...
- java编程思想第四版第三章要点习题
使用"简短的" 和正常的 打印语句来编写一个程序 package net.mindview.util; public class Print { /** * 不带有回车 * @pa ...
- pat 1092 To Buy or Not to Buy(20 分)
1092 To Buy or Not to Buy(20 分) Eva would like to make a string of beads with her favorite colors so ...
- Java编程思想——第14章 类型信息(二)反射
六.反射:运行时的类信息 我们已经知道了,在编译时,编译器必须知道所有要通过RTTI来处理的类.而反射提供了一种机制——用来检查可用的方法,并返回方法名.区别就在于RTTI是处理已知类的,而反射用于处 ...
- 深度剖析Javascript执行环境、作用域链
一.执行环境 执行环境(也叫做执行上下文,Execution Context)是Javascript中最为重要的一个概念.执行环境定义了变量或函数有权访问其他数据,决定了它们各自的行为.每个执行环境都 ...
- wait()、notify、notifyAll()的使用
wait().notify.notifyAll()的使用 参考:https://www.jianshu.com/p/25e243850bd2?appinstall=0 一).java 中对象锁的模型 ...
- LaravelS - 基于Swoole加速Laravel/Lumen
LaravelS LaravelS是一个胶水项目,用于快速集成Swoole到Laravel或Lumen,然后赋予它们更好的性能.更多可能性.Github 特性 内置Http/WebSocket服务器 ...
- GeoServer 查询sql视图
说明: 最近项目中遇到一个需求,需要统计管网的长度,但管网数据量非常大,前端用openlayers接口统计直接就奔溃了. 后尝试使用调后台接口查数据库的方式,虽然可行但是又要多一层与后台交互的工作. ...
- ASP.NET Core gRPC 使用 Consul 服务注册发现
一. 前言 gRPC 在当前最常见的应用就是在微服务场景中,所以不可避免的会有服务注册与发现问题,我们使用gRPC实现的服务可以使用 Consul 或者 etcd 作为服务注册与发现中心,本文主要介绍 ...
- 洛谷P2634 聪聪可可 (点分治)
###题目链接### 题目大意: 给你一棵树,假如树上两点间的距离是 3 的倍数 的点对有 s 对,则输出最简分数 s/n ,其中 n 表示所有整棵树的点对总数. 分析: 1.显然,可以采用点分治. ...