传送门

好久没做网络流方面的题发现自己啥都不会了qwq

题意:给一张有向图,让你用最少的简单路径覆盖所有的点。

考虑这样一个东西,刚开始,我们有\(n\)条路径,每条路径就是单一的一个点,那么我们的目的就是进行若干次操作将路径两两合并,这样对于一个以节点\(x\),它作为路径的端点最多被合并两次(一次连出边一次连入边)。

于是考虑二分图,将点\(x\)炸成两个点\(x_0,x_1\),\(x_0\)表示\(x\)连出去的出边,\(x_1\)表示\(x\)连进来的入边。那么对于图上一条\(u \rightarrow v\)的路径,在\(u_0,v_1\)之间连一条边,表示合并一条\(u\)为端点的路径和一条\(v\)为端点的路径。

这样,在合法的情况下最大的合并次数就是这张二分图的最大匹配数。

最小的路径条数就是\(n-\)最大匹配。匈牙利或者网络流啥的求出最大匹配,然后打印方案的话就对整张图照着最大匹配中的边\(Dfs\)一遍。

网络流的代码 还是感觉匈牙利好写......:

#include <bits/stdc++.h>
using namespace std;
#define rep(i,a,b) for (int i=(a);i<(b);++i)
#define per(i,a,b) for (int i=(a)-1;i>=(b);--i)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define all(x) (x).begin(),(x).end()
#define SZ(x) ((int)(x).size())
typedef double db;
typedef long long ll;
typedef pair<int,int> PII;
typedef vector<int> VI; const int N=1e5+10,INF=0x3f3f3f3f; struct Dinic {
int n,S,T;
int to[N<<1],nxt[N<<1],fst[N],cap[N<<1],flow[N<<1],cnt=0; inline void ade(int x,int y,int w) {
to[++cnt]=y,cap[cnt]=w,flow[cnt]=0;
nxt[cnt]=fst[x],fst[x]=cnt;
}
inline void addedge(int x,int y,int w) {ade(x,y,w),ade(y,x,0);} int d[N],q[N];
bool bfs() {
rep(i,0,n+1) d[i]=0;
int tn=1; q[0]=S;
d[S]=1;
rep(_,0,tn) {
int u=q[_];
for(int i=fst[u];i;i=nxt[i]) {
int v=to[i];
if(d[v]==0&&cap[i]>flow[i]) {
d[v]=d[u]+1;
q[tn++]=v;
}
}
}
return d[T]!=0;
} int cur[N];
int dfs(int x,int ag) {
if(x==T||ag==0) return ag;
for(int &i=cur[x];i;i=nxt[i]) {
int v=to[i];
if(cap[i]>flow[i]&&d[v]==d[x]+1) {
int out=dfs(v,min(ag,cap[i]-flow[i]));
if(out) {
flow[i]+=out;
flow[i^1]-=out;
return out;
}
else d[v]=0;
}
}
return 0;
} int Maxflow() {
int ans=0,out=0;
while(bfs()) {
rep(i,0,n+1) cur[i]=fst[i];
while(out=dfs(S,1e9)) ans+=out;
}
return ans;
} void init(int tn,int s,int t) {
S=s,T=t,n=tn;
rep(i,0,n+1) fst[i]=0;
cnt=1;
}
}flow; #define IDL(x) (x)
#define IDR(x) ((x)+n)
#define NODE(x) ((x)<=n?(x):(x)-n)
int n,m;
int vis[233][233],mark[N];
VI g[N]; void dfs(int x) {
printf("%d ",x);
mark[x]=1;
for(auto v:g[x]) if(vis[x][v])
dfs(v);
} int main() {
scanf("%d%d",&n,&m);
const int S=n*2+1,T=n*2+2;
flow.init(n*2+5,S,T);
rep(i,1,n+1) flow.addedge(S,IDL(i),1),flow.addedge(IDR(i),T,1);
rep(i,0,m) {
int x,y; scanf("%d%d",&x,&y);
flow.addedge(IDL(x),IDR(y),INF);
g[x].pb(y);
}
int ans=n-flow.Maxflow();
rep(i,2,flow.cnt+1) if(flow.flow[i]==1)
vis[NODE(flow.to[i^1])][NODE(flow.to[i])]=1;
rep(i,1,n) if(!mark[i]) dfs(i),puts("");
printf("%d\n",ans);
return 0;
}

[题解] LuoguP2764 最小路径覆盖问题的更多相关文章

  1. LuoguP2764 最小路径覆盖问题(最大流)

    题目描述 «问题描述: 给定有向图G=(V,E).设P 是G 的一个简单路(顶点不相交)的集合.如果V 中每个顶点恰好在P 的一条路上,则称P是G 的一个路径覆盖.P 中路径可以从V 的任何一个顶点开 ...

  2. [luoguP2764] 最小路径覆盖问题(最大流 || 二分图最大匹配)

    传送门 可惜洛谷上没有special judge,不然用匈牙利也可以过的,因为匈牙利在增广上有一个顺序问题,所以没有special judge就过不了了. 好在这个题的测试数据比较特殊,如果是网络流的 ...

  3. poj2594 机器人寻找宝藏(最小路径覆盖)

    题目来源:http://poj.org/problem?id=2594 参考博客:http://www.cnblogs.com/ka200812/archive/2011/07/31/2122641. ...

  4. UVALive3126 Taxi Cab Scheme —— 最小路径覆盖

    题目链接:https://vjudge.net/problem/UVALive-3126 题解: 最小路径覆盖:即在图中找出尽量少的路径,使得每个结点恰好只存在于一条路径上.其中单独一个点也可以是一条 ...

  5. UVALive - 7368 Airports DAG图的最小路径覆盖

    题目链接: http://acm.hust.edu.cn/vjudge/problem/356788 Airports Time Limit: 3000MS 问题描述 An airline compa ...

  6. poj 2060 Taxi Cab Scheme (最小路径覆盖)

    http://poj.org/problem?id=2060 Taxi Cab Scheme Time Limit: 1000MS   Memory Limit: 30000K Total Submi ...

  7. hdoj 3861 The King’s Problem【强连通缩点建图&&最小路径覆盖】

    The King’s Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  8. POJ1422 Air Raid 【DAG最小路径覆盖】

    Air Raid Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 6763   Accepted: 4034 Descript ...

  9. 【PowerOJ1738】最小路径覆盖

    Description 给定有向图G=(V,E).设P 是G 的一个简单路(顶点不相交)的集合.如果V 中每个 顶点恰好在P 的一条路上,则称P是G 的一个路径覆盖.P 中路径可以从V 的任何一个顶 ...

随机推荐

  1. Spring学习(四)

    Spring Ioc容器 1.具有依赖注入功能的容器.负责实例化,定位,配置应用程序中的对象及建立这些对象间的依赖.在Spring中BeanFactory是Ioc容器的实际代表者.BeanFactor ...

  2. Python数据类型-4 列表

    列表 列表是Python中最基本也是最常用的数据结构之一.列表中的每个元素都被分配一个数字作为索引,用来表示该元素在列表内所排在的位置.第一个元素的索引是0,第二个索引是1,依此类推. Python的 ...

  3. 一、log4j日志框架的理论和不同场景使用

    1.日志框架: 工作中要进行Java输出日志时,你需要一个或者多个日志框架.框架能提供对象.方法和必要的配置来发送日志信息.Java语言本身有自带的日志实现包java.util.logging.还有很 ...

  4. SystemVerilog for design 笔记(二)

    转载请标明出处 1. System Verilog文本值和数据类型 1.1. 增强的文本值赋值 相对于verilog,SV在文本值赋值时可以1.无需指定进制    2.赋值可以是逻辑1 用法: reg ...

  5. 使用display inline-block 布局时,出现的间距问题的解决办法和相关说明

    在CSS中,块级对象元素会单独占一行显示,多个block元素会各自新起一行.而内联对象元素前后不会产生换行,一系列inline元素都在一行内显示,直到该行排满. 使用 display inline-b ...

  6. Linux CentOS7 VMware LAMP架构Apache用户认证、域名跳转、Apache访问日志

    一.Apache用户认证 vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf //把111.com那个虚拟主机编辑成如下内容 <Virtu ...

  7. 设计模式课程 设计模式精讲 12-2 适配器模式coding

    1 重要 1.1 类适配器和对象适配器最大的区别 2 代码演练 2.1 代码演练1(类适配器模式) 2.2 代码演练2(对象适配模式) 2.3 代码演练3(具体应用场景) 1 重要 1.1 类适配器和 ...

  8. Tomcat的部署、虚拟主机及优化

    Tomcat的部署.虚拟主机及优化 文章目录 Tomcat的部署.虚拟主机及优化 前言 1.Tomcat的名称由来 2.Apache Tomcat 5-7版本差异 2.1Apache Tomcat5. ...

  9. 认识iOS系统架构

    关于本文: 文章主要介绍iOS系统架构中的四层结构的内容.常用的框架.大致的功能,然后对iOS开发人员的发展提出自己的一些拙见. 一.iOS系统是基于UNIX系统,所有从系统稳定性上来说的确比其他操作 ...

  10. CSS相关(1)

    CSS: 字体: 网页默认字体16px; 网站通用字体大小14px 最小是12px,最大无限大 单位换算:1em=16px 选择器:标签选择器:选择页面中所有指定标签,权重为1 通配符选择器:选择所有 ...