题面

传送门

题目大意:

有n条线段,每条线段染红色或蓝色,使得数轴上每个点被红色线段覆盖的次数与被蓝色线段覆盖数差的绝对值小于等于1。输出染色方案。

分析

题意其实可以这样理解:

一段初始全为0 的序列a,给区间[li,ri]" role="presentation">[li,ri][li,ri]+1或-1,使得操作结束后序列中的所有位置绝对值不超过1

可采用差分的思想,给al+1,ar+1−1" role="presentation">al+1,ar+1−1al+1,ar+1−1把区间操作转化成单点操作

因此我们可以建图来模拟这个过程,从l到r+1连一条边,每个点的值就是入度与出度的差

建完图后,会出现多个连通块,若联通块是欧拉回路,则区间值为0

但是,图中会存在许多奇数度的点,必须要连边.

如果从一个奇点到另一个奇点连一条边,如果区间内还有一个奇点,则该点可能会被一种颜色覆盖多次,导致绝对值大于1

所以只能将相邻的奇点连边

总结:

1.线段右端点+1,离散化

2.将相邻奇数点连边,跑欧拉回路

3.输出方案,如果边是从左到右的,输出0,否则输出1

代码

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<algorithm>
  5. #include<vector>
  6. #include<stack>
  7. #define maxn 200005
  8. using namespace std;
  9. int n;
  10. struct seg{
  11. int l;
  12. int r;
  13. int dl;
  14. int dr;
  15. }a[maxn];
  16. int m=0;
  17. int tmp[maxn<<2];
  18. int deg[maxn];
  19. struct edge{
  20. int from;
  21. int to;
  22. int next;
  23. }E[maxn<<2];
  24. int size=1;//从1开始存,这样一对反向边会存储在i和i^1的位置
  25. int head[maxn];
  26. int dir[maxn<<2];//记录每条边的方向
  27. int used[maxn];
  28. void add_edge(int u,int v){
  29. size++;
  30. E[size].from=u;
  31. E[size].to=v;
  32. E[size].next=head[u];
  33. head[u]=size;
  34. }
  35. void dfs(int x){
  36. // printf("%d\n",x);
  37. used[x]=1;
  38. for(int i=head[x];i;i=E[i].next){
  39. if(dir[i>>1]==-1){
  40. dir[i>>1]=(i&1)^1;//如果i%2==1,则是从左到右的边,dir=0,否则dir=1
  41. dfs(E[i].to);
  42. }
  43. }
  44. }
  45. int main(){
  46. scanf("%d",&n);
  47. for(int i=1;i<=n;i++){
  48. scanf("%d %d",&a[i].l,&a[i].r);//区间很大,必须离散化
  49. a[i].r++;
  50. tmp[++m]=a[i].l;
  51. tmp[++m]=a[i].r;
  52. }
  53. sort(tmp+1,tmp+1+m);
  54. m=unique(tmp+1,tmp+1+m)-tmp-1;
  55. for(int i=1;i<=n;i++){
  56. a[i].dl=lower_bound(tmp+1,tmp+1+m,a[i].l)-tmp;
  57. a[i].dr=lower_bound(tmp+1,tmp+1+m,a[i].r)-tmp;
  58. add_edge(a[i].dl,a[i].dr);//连边
  59. add_edge(a[i].dr,a[i].dl);
  60. deg[a[i].dl]++;
  61. deg[a[i].dr]++;
  62. }
  63. // printf("%d\n",m);
  64. int pre=0;
  65. for(int i=1;i<=m;i++){
  66. if(deg[i]%2&&pre!=0){//相邻的奇数点连边
  67. add_edge(i,pre);
  68. add_edge(pre,i);
  69. pre=0;
  70. }else if(deg[i]%2){
  71. pre=i;
  72. }
  73. }
  74. for(int i=1;i<=size/2;i++){
  75. dir[i]=-1;
  76. }
  77. for(int i=1;i<=m;i++){
  78. if(!used[i]) dfs(i);//欧拉回路
  79. }
  80. for(int i=1;i<=n;i++){
  81. printf("%d ",dir[i]);
  82. }
  83. }

Codeforces 429E(欧拉回路)的更多相关文章

  1. Codeforces 429E - Points and Segments(欧拉回路)

    Codeforces 题面传送门 & 洛谷题面传送门 果然我不具备融会贯通的能力/ll 看到这样的设问我们可以很自然地联想到这道题,具体来说我们可以通过某种方式建出一张图,然后根据" ...

  2. Codeforces 429E Points and Segments

    Description 题面 题目大意:有 \(n\) 个区间 \([L_i,R_i]\) ,你要给每一个区间染红蓝,使得每一个位置被红色染过的次数与被蓝色染过的次数差的绝对值不大于\(1\) Sol ...

  3. A - Points and Segments CodeForces - 429E

    题解: 方法非常巧妙的一道题 首先考虑要求全部为0怎么做 发现是个欧拉回路的问题(很巧妙) 直接dfs一遍就可以了 而这道题 要求是-1,1,0 我们可以先离散化 完了之后判断每个点被奇数还是偶数条边 ...

  4. Tanya and Password CodeForces - 508D (欧拉回路)

    大意:给定n个长为3的子串, 求一个长为n+2的字符串包含所有子串. 相邻两个字符开一个节点, 建图跑欧拉回路, 若存在的话长度一定是$\le n+2$.

  5. codeforces 429E

    题意:给定n<=100000线段[l,r],然后给这些线段染色(red or blue),求最后平面上任意一个点被蓝色及红色覆盖次数只差的绝对值不大于1 思路:把每条线段拆成2个点[l<& ...

  6. Codeforces Round #296 (Div. 1) C. Data Center Drama 欧拉回路

    Codeforces Round #296 (Div. 1)C. Data Center Drama Time Limit: 2 Sec  Memory Limit: 256 MBSubmit: xx ...

  7. Codeforces Gym 100431A Achromatic Number 欧拉回路

    原题链接:http://codeforces.com/gym/100431/attachments/download/2421/20092010-winter-petrozavodsk-camp-an ...

  8. Codeforces 1499G - Graph Coloring(带权并查集+欧拉回路)

    Codeforces 题面传送门 & 洛谷题面传送门 一道非常神仙的题 %%%%%%%%%%%% 首先看到这样的设问,做题数量多一点的同学不难想到这个题.事实上对于此题而言,题面中那个&quo ...

  9. Codeforces 1361C - Johnny and Megan's Necklace(欧拉回路)

    Codeforces 题目传送门 & 洛谷题目传送门 u1s1 感觉这个题作为 D1C 还是蛮合适的-- 首先不难发现答案不超过 \(20\),所以可以直接暴力枚举答案并 check 答案是否 ...

随机推荐

  1. 什么是LMDB闪电记忆映射数据库

    LightningMemory-MappedDatabase(LMDB)是一个软件库,它以键值存储的形式提供高性能的嵌入式事务数据库.LMDB是用C语言编写的,具有多种编程语言的API绑定.LMDB将 ...

  2. 【bzoj4552】【Tjoi2016&Heoi2016】【NOIP2016模拟7.12】排序

    题目 在2016年,佳媛姐姐喜欢上了数字序列.因而他经常研究关于序列的一些奇奇怪怪的问题,现在他在研究一个难题,需要你来帮助他.这个难题是这样子的:给出一个1到n的全排列,现在对这个全排列序列进行m次 ...

  3. elementui多个文件上传问题

    我认为绑定一个值 然后把值改变不同的名字即可

  4. vue安装 js-cookie

    首先在命令行工具输入:npm install vue-js-cookie 安装完成之后在需要使用的页面导入:import Cookies from 'js-cookie' 这样就可以使用了,如下图,先 ...

  5. node.js 的 中间件 初理解

    听说中间件还挺重要,下面梳理一下初认识: 中间件是什么?简单说说http请求服务的过滤,当交给函数处理之前先交给它处理.匹配后会终止,要想再匹配,得加: next. 中间件能解决什么问题?检测用户登录 ...

  6. rk3328设备树学习

    一.用到的rk3328好像使用了设备树 设备树我知道的有三种文件类型,dtbs是通过指令make dtbs编译的二进制文件,供内核使用. 基于同样的软件分层设计的思想,由于一个SoC可能对应多个mac ...

  7. Bugku web 计算器

    计算器 打开网页,想输入正确的计算结果发现只输进去一位数??? 遇事不决先F12看一眼源码,发现flag

  8. WEB上传一个文件夹

    在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 先说下要求: PC端全平台支持,要求支持Windows,Mac,Linux 支持所 ...

  9. HDU 6153 A Secret ( KMP&&DP || 拓展KMP )

    题意 : 给出两个字符串,现在需要求一个和sum,考虑第二个字符串的所有后缀,每个后缀对于这个sum的贡献是这个后缀在第一个字符串出现的次数*后缀的长度,最后输出的答案应当是 sum % 1e9+7 ...

  10. Java——常用类(File)

    [File]    <1>java.io.File类代表系统文件名(路径和文件名).         ----注意:这里代表的只是文件名,而不是物理上的文件(硬盘上的数据),通过该类无法读 ...