【Luogu2711】小行星(网络流,最大流)

题面

题目描述

星云中有n颗行星,每颗行星的位置是(x,y,z)。每次可以消除一个面(即x,y或z坐标相等)的行星,但是由于时间有限,求消除这些行星的最少次数。

输入输出格式

输入格式:

第1行为小行星个数n,第2行至第n+1行为xi, yi, zi,描述第i个小行星所在的位置。

输出格式:

共1行,为消除所有行星的最少次数。

输入输出样例

输入样例#1:

3

1 2 3

2 3 1

1 3 2

输出样例#1:

2

说明

1≤n≤50000

1≤x,y,z≤500

题解

完全类似于二分图的匹配

只是多加了一维

因此,相当于是建造一个三分图,连边后求最小割

但是不能够直接\(x->y->z\)这样连边

否则显然是错误的

这样的话\(y\)没有任何限制作用

因此连边是\(x->y->y'->z\)

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<cmath>
  6. #include<algorithm>
  7. #include<set>
  8. #include<map>
  9. #include<vector>
  10. #include<queue>
  11. using namespace std;
  12. #define MAX 3000
  13. #define MAXL 5000000
  14. #define INF 100000000
  15. inline int read()
  16. {
  17. int x=0,t=1;char ch=getchar();
  18. while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
  19. if(ch=='-')t=-1,ch=getchar();
  20. while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
  21. return x*t;
  22. }
  23. struct Line
  24. {
  25. int v,next,w;
  26. }e[MAXL];
  27. int h[MAX],cnt;
  28. int ans,S,T;
  29. int n;
  30. inline void Add(int u,int v,int w)
  31. {
  32. e[cnt]=(Line){v,h[u],w};
  33. h[u]=cnt++;
  34. e[cnt]=(Line){u,h[v],0};
  35. h[v]=cnt++;
  36. }
  37. int level[MAX],cur[MAX];
  38. bool BFS()
  39. {
  40. memset(level,0,sizeof(level));
  41. level[S]=1;
  42. queue<int> Q;
  43. Q.push(S);
  44. while(!Q.empty())
  45. {
  46. int u=Q.front();Q.pop();
  47. for(int i=h[u];i!=-1;i=e[i].next)
  48. {
  49. int v=e[i].v;
  50. if(e[i].w&&!level[v])
  51. level[v]=level[u]+1,Q.push(v);
  52. }
  53. }
  54. return level[T];
  55. }
  56. int DFS(int u,int flow)
  57. {
  58. if(flow==0||u==T)return flow;
  59. int ret=0;
  60. for(int &i=cur[u];i!=-1;i=e[i].next)
  61. {
  62. int v=e[i].v;
  63. if(e[i].w&&level[v]==level[u]+1)
  64. {
  65. int dd=DFS(v,min(flow,e[i].w));
  66. flow-=dd;ret+=dd;
  67. e[i].w-=dd;e[i^1].w+=dd;
  68. }
  69. }
  70. return ret;
  71. }
  72. int Dinic()
  73. {
  74. int ret=0;
  75. while(BFS())
  76. {
  77. for(int i=S;i<=T;++i)cur[i]=h[i];
  78. ret+=DFS(S,INF);
  79. }
  80. return ret;
  81. }
  82. int main()
  83. {
  84. memset(h,-1,sizeof(h));
  85. n=read();
  86. S=0;T=2001;
  87. for(int i=1;i<=500;++i)Add(S,i,1),Add(i+1500,T,1),Add(i+500,i+1000,1);
  88. for(int i=1;i<=n;++i)
  89. {
  90. int x=read(),y=read(),z=read();
  91. Add(x,y+500,INF);Add(y+1000,z+1500,INF);
  92. }
  93. printf("%d\n",Dinic());
  94. return 0;
  95. }

【Luogu2711】小行星(网络流,最大流)的更多相关文章

  1. POJ 1459-Power Network(网络流-最大流-ISAP)C++

    Power Network 时间限制: 1 Sec  内存限制: 128 MB 题目描述 A power network consists of nodes (power stations, cons ...

  2. [POJ1273][USACO4.2]Drainage Ditches (网络流最大流)

    题意 网络流最大流模板 思路 EK也不会超时 所以说是一个数据比较水的模板题 但是POJ有点坑,多组数据,而且题目没给 哭得我AC率直掉 代码 用的朴素Dinic #include<cstdio ...

  3. HDU 3081 Marriage Match II (网络流,最大流,二分,并查集)

    HDU 3081 Marriage Match II (网络流,最大流,二分,并查集) Description Presumably, you all have known the question ...

  4. HDU1532 网络流最大流【EK算法】(模板题)

    <题目链接> 题目大意: 一个农夫他家的农田每次下雨都会被淹,所以这个农夫就修建了排水系统,还聪明的给每个排水管道设置了最大流量:首先输入两个数n,m ;n为排水管道的数量,m为节点的数量 ...

  5. Redraw Beautiful Drawings(hdu4888)网络流+最大流

    Redraw Beautiful Drawings Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/O ...

  6. A simple Gaussian elimination problem.(hdu4975)网络流+最大流

    A simple Gaussian elimination problem. Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65 ...

  7. 【bzoj3130】[Sdoi2013]费用流 二分+网络流最大流

    题目描述 Alice和Bob做游戏,给出一张有向图表示运输网络,Alice先给Bob一种最大流方案,然后Bob在所有边上分配总和等于P的非负费用.Alice希望总费用尽量小,而Bob希望总费用尽量大. ...

  8. 【bzoj1822】[JSOI2010]Frozen Nova 冷冻波 计算几何+二分+网络流最大流

    题目描述 WJJ喜欢“魔兽争霸”这个游戏.在游戏中,巫妖是一种强大的英雄,它的技能Frozen Nova每次可以杀死一个小精灵.我们认为,巫妖和小精灵都可以看成是平面上的点. 当巫妖和小精灵之间的直线 ...

  9. 【bzoj1733】[Usaco2005 feb]Secret Milking Machine 神秘的挤奶机 二分+网络流最大流

    题目描述 Farmer John is constructing a new milking machine and wishes to keep it secret as long as possi ...

  10. 【bzoj1532】[POI2005]Kos-Dicing 二分+网络流最大流

    题目描述 Dicing 是一个两人玩的游戏,这个游戏在Byteotia非常流行. 甚至人们专门成立了这个游戏的一个俱乐部. 俱乐部的人时常在一起玩这个游戏然后评选出玩得最好的人.现在有一个非常不走运的 ...

随机推荐

  1. Windows Server 2016-抢占FSMO角色

    很多情况下,当生产域控制器发生问题无法修复的情况下,我们只能通过抢占FSMO角色以保证用户验证等正常或及时恢复.一般在同一个域环境中,我们往往都会有主备或主辅域控规划,平时工作的时候,两台域控可以实现 ...

  2. java泛型类的继承规则

    首先看一看java泛型类的使用: /** * 一个泛型方法:使程序更加安全 * 并且能被更多的使用 * @author 丁** * * @param <T> */ class Pair&l ...

  3. 关于eclipse安装springide的记录

    近些天,又开始学习springmvc,使用eclipse进行开发,由于很多快捷键时候需要安装springide插件才能出来,我遇到配置DispatcherServlet,结果alt+/出不来Dispa ...

  4. C#获取文件夹下的所有文件的文件名(转载)

    String path = @"X:\xxx\xxx";   //第一种方法 var files = Directory.GetFiles(path, "*.txt&qu ...

  5. Nuget发布自己的DLL

          首先说明背景,在asp.net core开发中,使用了Oracle,Oracle官方发布了一个新的sdk用于连接数据库,但是asp.net core有个特性,就是不支持直接引用dll,也就 ...

  6. iOS原生和H5的相互调用

    为什么现在越来越多的APP中开始出现H5页面? 1,H5页面开发效率更高,更改更加方便: 2,适当缩小APP安装包的大小: 3,蹭热点更加方便,比如五一,十一,双十一搞活动: 那么为什么说H5无法取代 ...

  7. 1.12 dict 字典表

    dict 字典表属于映射分类 dict的声明 >>> #dict类型 是 {}中包含若干个键值对 >>> d = dict() >>> d = { ...

  8. SIFT解析(一)建立高斯金字塔

    SIFT(Scale-Invariant Feature Transform,尺度不变特征转换)在目标识别.图像配准领域具有广泛的应用,下面按照SIFT特征的算法流程对其进行简要介绍对SIFT特征做简 ...

  9. duilib界面库学习(仿PC微信界面,有服务器,有数据库,可以网络通信)

    客户端代码:https://github.com/TTGuoying/duilib_ChatClient 服务器代码:https://github.com/TTGuoying/duilib_ChatS ...

  10. 安装VMware Workstation提示the msi failed的解决办法

    有朋友安装VMware Workstation时出现报错,提示the msi failed等信息,原来他以前安装过绿色版.优化版的VM,但删掉后重装VM就会有这样的报错提示,如果你也遇到了相同的困扰, ...