从零单练网络流 第三章 有上下界的可行流

2023-10-17 18:32

本文主要是介绍从零单练网络流 第三章 有上下界的可行流,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

可行流无非就是把给定的一些条件转化为最大流可以完成的任务,著名的题目有SGU上的两道题P194 Reactor Cooling和P176 Flow Construction。第一题我本想依靠自己想出最大流的模型,不过最后还是看了题解。


这里简要讲一下P194 Reactor Cooling这道题的解法,这题在ACdream上也有,P1211。题意大概为给你n个点,m条边,每条边有上下界流,然后要保证每个点出流和入流一样。

建立超级源st和超级汇tr,对于每条边的容量为自己上下界流之差,记录每个点入出流情况。假如入流多,那st到该点加一条边即多出来的入流,反之,就该点引边向tr,值是这个绝对值。至于为什么这样,只有自己模拟一遍,自己说服自己了,说实在是说不清楚。不过有一点可以帮助你理解,这道题判断是否可行,是要st每条边都满流,之前因为st的边是由入流情况决定的,而其他边是上下界之差,即其他边是忽略了下界的判断的,那所有关于下界的判断全部集中于st引出的边,st引出的边正是保证他们下界之上的关键,而上下界之差的边则控制了上界。那为什么st引出的边保证了他们下界之上呢?因为假如每条边都是下界,那有些点必溢出,这些溢出的流则由超级源提供了。上下界之差控制上界应该好理解。

你理解了吗?


Reactor Cooling的代码:

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<ctime>
#include<string>
#include<cstring>
#include<algorithm>
#include<fstream>
#include<queue>
#include<stack> 
#include<vector>
#include<cmath>
#include<iomanip>
#define rep(i,n) for(i=1;i<=n;i++)
#define MM(a,t) memset(a,t,sizeof(a))
#define INF 1e9
typedef long long ll;
#define mod 1000000007
using namespace std; 
int n,m,np,nc,st,tr; 
int res;
struct edge{int s,e,lest;
}eg[40020];
int w[220][220],inout[220];
int gap[220],dis[220],pre[220];
queue<int> Q;
void BFS(){int i,j;MM(gap,0); MM(dis,0);dis[tr]=0; gap[0]=1;while(!Q.empty()) Q.pop(); Q.push(tr);while(!Q.empty()){int s,e=Q.front(); Q.pop();for(s=0;s<=n;s++)if(!dis[s] && w[s][e]){dis[s]=dis[e]+1;gap[dis[s]]++; Q.push(s);}} //for(i=0;i<=n;i++) cout<<dis[i]<<' '; cout<<'\n';
}
int ISAP(){BFS();	int i,u=st,j,ans=0,md;pre[st]=-1;while(dis[u]<=n){if(u==tr){int minflow=INF;for(i=pre[u];i!=-1;u=i,i=pre[i])  minflow=min(minflow,w[i][u]);for(i=pre[u=tr];i!=-1;u=i,i=pre[i]){w[i][u]-=minflow;w[u][i]+=minflow;}	ans+=minflow;}for(i=0;i<=n;i++)if(w[u][i]>0 && dis[i]+1==dis[u]) break;if(i<=n){pre[i]=u;u=i;}else{if(--gap[dis[u]]==0) break;for(md=n,i=0;i<=n;i++)if(w[u][i]>0) md=min(md,dis[i]);dis[u]=md+1;gap[dis[u]]++;if(u!=st) u=pre[u];}}return ans;
}
int main()
{int i,j,i1,i2,i3;string si;while(scanf("%d%d",&n,&m)!=EOF){MM(w,0); MM(inout,0);rep(i,m){int s,e,v1,v2;scanf("%d%d%d%d",&s,&e,&v1,&v2);eg[i].s=s; eg[i].e=e; eg[i].lest=v1;inout[s]-=v1; inout[e]+=v1;w[s][e]=v2-v1;} st=0; tr=n+1; n++;rep(i,n-1)if(inout[i]<0) w[i][tr]=-inout[i];else           w[st][i]=inout[i];ISAP();bool ff=true;rep(i,n-1)if(w[st][i]!=0){ff=false;break;	} if(!ff) printf("NO\n");else{printf("YES\n");rep(i,m) printf("%d\n",eg[i].lest+w[eg[i].e][eg[i].s]);	}}return 0;
}


这篇关于从零单练网络流 第三章 有上下界的可行流的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/227199

相关文章

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了