二次联通门 : LibreOJ #6000. 「网络流 24 题」搭配飞行员

  1. /*
  2. LibreOJ #6000. 「网络流 24 题」搭配飞行员
  3.  
  4. 二分图最大匹配
  5. Dinic最大流 + 当前弧优化
  6.  
  7. */
  8. #include <cstring>
  9. #include <cstdio>
  10. #include <queue>
  11.  
  12. #define Max 10000
  13. #define INF 1e5
  14.  
  15. int read (int &now)
  16. {
  17. now = ;
  18. register char word = getchar ();
  19. while (word < '' || word > '')
  20. word = getchar ();
  21. while (word >= '' && word <= '')
  22. {
  23. now = now * + word - '';
  24. word = getchar ();
  25. }
  26. if (now >= )
  27. return ;
  28. }
  29.  
  30. inline int min (int a, int b)
  31. {
  32. return a < b ? a : b;
  33. }
  34.  
  35. class Net_Flow_Type
  36. {
  37.  
  38. private :
  39.  
  40. int __to[Max << ], __next[Max << ];
  41.  
  42. int __flow[Max << ];
  43.  
  44. int edge_list[Max];
  45. int Edge_Count;
  46.  
  47. int deep[Max], __tech_[Max];
  48. int T;
  49.  
  50. int Answer;
  51.  
  52. public :
  53.  
  54. Net_Flow_Type ()
  55. {
  56. Edge_Count = ;
  57. }
  58.  
  59. inline void Insert_edge (int from, int to)
  60. {
  61. Edge_Count ++;
  62.  
  63. __to[Edge_Count] = to;
  64. __next[Edge_Count] = edge_list[from];
  65. edge_list[from] = Edge_Count;
  66.  
  67. Edge_Count ++;
  68.  
  69. __to[Edge_Count] = from;
  70. __next[Edge_Count] = edge_list[to];
  71. edge_list[to] = Edge_Count;
  72.  
  73. __flow[Edge_Count - ] = ;
  74. __flow[Edge_Count] = ;
  75. }
  76.  
  77. bool Bfs (int Start, int End)
  78. {
  79. std :: queue <int> Queue;
  80.  
  81. Queue.push (Start);
  82. memset (deep, -, sizeof deep);
  83.  
  84. int now;
  85. for (deep[Start] = ; !Queue.empty (); Queue.pop ())
  86. {
  87. now = Queue.front ();
  88.  
  89. for (int i = edge_list[now]; i; i = __next[i])
  90. if (__flow[i] && deep[__to[i]] == -)
  91. {
  92. deep[__to[i]] = deep[now] + ;
  93. if (__to[i] == End)
  94. return true;
  95. Queue.push (__to[i]);
  96. }
  97. }
  98.  
  99. return deep[End] != -;
  100. }
  101.  
  102. int Flowing (int now, int flow)
  103. {
  104. if (now == T || flow <= )
  105. return flow;
  106.  
  107. int res = , pos = ;
  108. for (int i = __tech_[now]; i; i = __next[i])
  109. {
  110. if (deep[__to[i]] != deep[now] + || __flow[i] <= )
  111. continue;
  112. res = Flowing (__to[i], min (flow, __flow[i]));
  113.  
  114. if (res > )
  115. {
  116. flow -= res;
  117. pos += res;
  118.  
  119. __flow[i] -= res;
  120. __flow[i ^ ] += res;
  121. if (__flow[i])
  122. __tech_[now] = i;
  123.  
  124. if (flow == )
  125. return pos;
  126. }
  127. }
  128. return pos;
  129. }
  130.  
  131. int Dinic (int Start, int End)
  132. {
  133. for (T = End; Bfs (Start, End); )
  134. {
  135. memcpy (__tech_, edge_list, sizeof edge_list);
  136.  
  137. Answer += Flowing (Start, INF);
  138. }
  139.  
  140. return Answer;
  141. }
  142.  
  143. };
  144.  
  145. int N, M;
  146. Net_Flow_Type Make;
  147.  
  148. int main (int argc, char *argv[])
  149. {
  150. read (N);
  151. read (M);
  152.  
  153. int S = N + , T = N + ;
  154.  
  155. for (int i = ; i <= M; i ++)
  156. Make.Insert_edge (S, i);
  157.  
  158. for (int i = M + ; i <= N; i ++)
  159. Make.Insert_edge (i, T);
  160.  
  161. for (int x, y; scanf ("%d %d", &x, &y) == ; Make.Insert_edge (x, y));
  162.  
  163. printf ("%d", Make.Dinic (S, T));
  164.  
  165. return ;
  166. }

LibreOJ #6000. 「网络流 24 题」搭配飞行员的更多相关文章

  1. LibreOJ #6000. 「网络流 24 题」搭配飞行员 最大匹配

    #6000. 「网络流 24 题」搭配飞行员 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据   题目描述 ...

  2. 【刷题】LOJ 6000 「网络流 24 题」搭配飞行员

    题目描述 飞行大队有若干个来自各地的驾驶员,专门驾驶一种型号的飞机,这种飞机每架有两个驾驶员,需一个正驾驶员和一个副驾驶员.由于种种原因,例如相互配合的问题,有些驾驶员不能在同一架飞机上飞行,问如何搭 ...

  3. Loj #6000.「 网络流 24 题 」搭配飞行员

    解题思路 考虑如何建模. 既然是网络流,那么肯定要有源点和汇点.而这个题目并没有什么明显的源点和汇点. 想一想,如果一个飞机能够起飞的话,那么必定有一对可以配对的正副驾驶员.也就是说一条曾广路能够上必 ...

  4. LOJ6000 - 「网络流 24 题」搭配飞行员

    原题链接 题意简述 求二分图的最大匹配. 题解 这里写的是匈牙利算法. 表示节点的当前匹配. 为真表示在这一轮匹配中,无法给节点一个新的匹配.所以如果为真就不用再dfs它了,直接continue就好. ...

  5. [日常摸鱼]loj6000「网络流 24 题」搭配飞行员

    题面 应该是二分图匹配,不过我写的是网络最大流. dinic求二分图最大匹配:加个源点和汇点,源点连向二分图的一边所有点,二分图的另一边所有点连向汇点,很明显这样得到的最大流就是这个二分图的最大匹配. ...

  6. LibreOJ #6002. 「网络流 24 题」最小路径覆盖

    #6002. 「网络流 24 题」最小路径覆盖 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:Special Judge 上传者: 匿名 提交提交记录统计讨论测 ...

  7. LibreOJ #6014. 「网络流 24 题」最长 k 可重区间集

    #6014. 「网络流 24 题」最长 k 可重区间集 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据   ...

  8. LibreOJ #6013. 「网络流 24 题」负载平衡 最小费用最大流 供应平衡问题

    #6013. 「网络流 24 题」负载平衡 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据   题目描述 ...

  9. LIbreOJ #6011. 「网络流 24 题」运输问题 最小费用最大流

    #6011. 「网络流 24 题」运输问题 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据   题目描述 ...

随机推荐

  1. CMake入门-04-自定义编译选项

    工作环境 系统:macOS Mojave 10.14.6 CMake: Version 3.15.0-rc4 Hello,World! - 自定义编译选项 CMake 允许为项目增加编译选项,从而可以 ...

  2. (十四)角色管理(Ztree插件的基本使用)

    1. 建表 角色表 菜单表 角色-菜单(这个表中的role_id和menuu_id都不能被设置为主键,否则当插入一个新角色的时候,一个角色可能拥有多个菜单(role_id重复),一个菜单可能被多个角色 ...

  3. 利用贝叶斯算法实现手写体识别(Python)

    在开始介绍之前,先了解贝叶斯理论知识 https://www.cnblogs.com/zhoulujun/p/8893393.html 简单来说就是:贝叶斯分类是一类分类算法的总称,这类算法均以贝叶斯 ...

  4. ubantu18.04 配置nginx与uwsgi(前后端分离)

    ubantu18.04 配置nginx与uwsgi   一.首先先安装nginx静态服务 先更新 sudo apt-get update 1.安装gcc g++的依赖库 sudo apt-get in ...

  5. Java基础加强-jdk1.5的一些新特性

    JDK 5.0 特性 1.静态导入(import static 语句导入一个类中的某个静态方法或所有静态方法) 如: import static java.lang.Math.*; 2.可变参数 1. ...

  6. 负载均衡之haproxy负载均衡算法及haproxy的工作模式

    haproxy负载均衡的算法有如下7种: .roundrobin : 基于权重轮循. static-rr : 基于权重轮循.静态算法,运行时改变无法生效 source : 基于请求源IP的算法.对请求 ...

  7. curl: (7) couldn't connect to host 解决方法

    使用curl命令访问网站时报错: [root@bqh-119 ~]# curl -I www.test.com curl: (7) couldn't connect to host [root@bqh ...

  8. MVC方式显示数据(手动添加数据)

    Model添加类 Customers using System; using System.Collections.Generic; using System.Linq; using System.W ...

  9. python Beautiful Soup 采集it books pdf,免费下载

    http://www.allitebooks.org/ 是我见过最良心的网站,所有书籍免费下载 周末无聊,尝试采集此站所有Pdf书籍. 采用技术 python3.5 Beautiful soup 分享 ...

  10. sql server 某一列求和

    sql server 某一列求和 SELECT 患者来源,设备类型,检查部位,设备名称,convert(char(10),STUDY_DATE,121) as 日期, count(distinct 就 ...