链接 CF429E Points and Segments

  • 给定\(n\)条线段,然后给这些线段红蓝染色,求最后直线上上任意一个点被蓝色及红色线段覆盖次数之差的绝对值不大于\(1\),构造方案,\(n\leq10^5\)
  • 欧拉回路。
  • 考虑差分的思想(一般这样的区间覆盖问题都可以转化成差分,变成两两匹配问题。),一个线段被染色也就是\(l++\),\((r+1)--\)
  • 设从\(l\)到\(r+1\)边为红色,\(r+1\)到\(l\)的边为蓝色。
  • 那么我们就在考虑怎么样遍历这张图,使得每个点入度出度差小于等于\(1\)。
  • 这样不好做,新加入一些\(0\)边,表示不做处理,也就是最后颜色之差等于\(1\)。
  • 问题就变成了找到一些路径使得每个点出度入度相等。
  • 求一个欧拉回路即可。
  1. //CF429E Points and Segments
  2. #include<bits/stdc++.h>
  3. #define R register int
  4. #define ll long long
  5. using namespace std;
  6. const int N=500001;
  7. int n,len,cnt,O[N],fid[N],vis[N],du[N];
  8. int hd[N],to[N],nt[N],w[N],ans[N];
  9. void link(R f,R t,R d){nt[++cnt]=hd[f],w[cnt]=d,to[cnt]=t,hd[f]=cnt;}
  10. struct Qs{int l,r;}Q[N];
  11. int gi(){
  12. R x=0,k=1;char c=getchar();
  13. while((c<'0'||c>'9')&&c!='-')c=getchar();
  14. if(c=='-')k=-1,c=getchar();
  15. while(c>='0'&&c<='9')x=(x<<3)+(x<<1)+c-'0',c=getchar();
  16. return x*k;
  17. }
  18. void Dfs(R i){
  19. fid[i]=1;
  20. for(R &k=hd[i];k;k=nt[k])
  21. if(!vis[k]){
  22. vis[k]=vis[k^1]=1,ans[w[k]]=(i<to[k]);
  23. Dfs(to[k]);
  24. }
  25. }
  26. int main(){
  27. n=gi(),cnt=1;
  28. for(R i=1;i<=n;++i){
  29. Q[i].l=gi(),Q[i].r=gi()+1;
  30. O[++len]=Q[i].l,O[++len]=Q[i].r;
  31. }
  32. sort(O+1,O+len+1),len=unique(O+1,O+len+1)-O-1;
  33. for(R i=1;i<=n;++i){
  34. Q[i].l=lower_bound(O+1,O+len+1,Q[i].l)-O;
  35. Q[i].r=lower_bound(O+1,O+len+1,Q[i].r)-O;
  36. link(Q[i].l,Q[i].r,i),link(Q[i].r,Q[i].l,i);
  37. du[Q[i].l]++,du[Q[i].r]++;
  38. }
  39. R las=0;
  40. for(R i=1;i<=len;++i)
  41. if(du[i]&1){
  42. if(las)link(las,i,0),link(i,las,0),du[i]++,du[las]++,las=0;
  43. else las=i;
  44. }
  45. for(R i=1;i<=len;++i)if(!fid[i])Dfs(i);
  46. for(R i=1;i<=n;++i)putchar(ans[i]+'0'),putchar(' ');
  47. return 0;
  48. }

CF429E Points and Segments的更多相关文章

  1. CF429E Points and Segments 构造、欧拉回路

    传送门 如果把一条线段\([l,r]\)看成一条无向边\((l,r+1)\),从\(l\)走到\(r+1\)表示线段\([l,r]\)染成红色,从\(r+1\)走到\(l\)表示线段\([l,r]\) ...

  2. 【CF429E】Points and Segments(欧拉回路)

    [CF429E]Points and Segments(欧拉回路) 题面 CF 洛谷 题解 欧拉回路有这样一个性质,如果把所有点在平面内排成一行,路径看成区间的覆盖,那么每个点被从左往右的覆盖次数等于 ...

  3. 【CF429E】Points and Segments 欧拉回路

    [CF429E]Points and Segments 题意:给你数轴上的n条线段$[l_i,r_i]$,你要给每条线段确定一个权值+1/-1,使得:对于数轴上的任一个点,所有包含它的线段的权值和只能 ...

  4. Codeforces Round #245 (Div. 2) A. Points and Segments (easy) 贪心

    A. Points and Segments (easy) Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://codeforces.com/con ...

  5. 『ACM C++』 Codeforces | 1066A - Points in Segments

    大一生活真 特么 ”丰富多彩“ ,多彩到我要忙到哭泣,身为班长,很多班级的事情需要管理,也是,什么东西都得体验学一学,从学生会主席.团委团总支.社团社长都体验过一番了,现在差个班长也没试过,就来体验了 ...

  6. Codeforces Round #501 (Div. 3) 1015A Points in Segments (前缀和)

    A. Points in Segments time limit per test 1 second memory limit per test 256 megabytes input standar ...

  7. [CF429E]Points ans Segments_欧拉回路

    Points and Segments 题目链接:www.codeforces.com/contest/429/problem/E 注释:略. 题解: 先离散化. 发现每个位置如果被偶数条线段覆盖的话 ...

  8. 【CF429E】 Points and Segments(欧拉回路)

    传送门 CodeForces 洛谷 Solution 考虑欧拉回路有一个性质. 如果把点抽出来搞成一条直线,路径看成区间覆盖,那么一个点从左往右被覆盖的次数等于从右往左被覆盖的次数. 发现这个性质和本 ...

  9. [UCSD白板题] Points and Segments

    Problem Introduction The goal in this problem is given a set of segments on a line and a set of poin ...

随机推荐

  1. shell scripts 编写基础

    一.shell变量的相关用法: 变量作为被赋值的一方的时候不加$,只有在使用其值的内容的时候需要加上$,该符号可 1,变量中的单引号‘’.双引号“”“.反单引号‵`.括号().大括号{}.双括号(() ...

  2. vue-router 2.0 跳转之router.push()

    router.push(location) 除了使用 创建 a 标签来定义导航链接,我们还可以借助 router 的实例方法,通过编写代码来实现. router.push(location) 想要导航 ...

  3. VMware 虚拟化编程(4) — VDDK 安装

    目录 目录 前文列表 VDDK 安装 VDDK 前文列表 VMware 虚拟化编程(1) - VMDK/VDDK/VixDiskLib/VADP 概念简析 VMware 虚拟化编程(2) - 虚拟磁盘 ...

  4. 阶段1 语言基础+高级_1-3-Java语言高级_02-继承与多态_第3节 接口_1_接口概述与生活举例

  5. 只有一个form 的程序, onactivate 只触发一次。

    https://blog.csdn.net/saint13/article/details/454615 Form的onActivate事件 2005年08月15日 01:08:00 阅读数:3406 ...

  6. ios平台appstore不支持网页内嵌app解决方案

    苹果一直拒绝 UIWebView 内嵌 HTML5 页面的 iPhone.iPad APP应用上架到 App Store,建议这样的APP去做成Safari的Web应用.但是,苹果的审核人员只从界面. ...

  7. jdk与eclipse安装注意事项

    1.安装这两个软件,一定要注意使得两个软件的版本是一致的: 1.1编写小程序测试jdk的版本号: public class Text{ public static void main(String[] ...

  8. SpringBoot 整合 MybatisPlus (项目的创建及简单的单表查询)

    添加依赖 <!--mybatis-plus的springboot支持--> <dependency> <groupId>com.baomidou</group ...

  9. Redis的持久化存储

    Redis的持久化 Redis 是一种内存型数据库,一旦服务器进程退出,数据库的数据就会丢失,为了解决这个问题, Redis 提供了两种持久化的方案,将内存中的数据保存到磁盘中,避免数据的丢失. RD ...

  10. Djaon 基于 Ajax 的 json 数据传输

    关键参数:contentType:"application/json" data:JSON.stringify({ json数据 }) 再views.py中,使用request.d ...