新用户注册入口 老用户登录入口

[转载]有汇源上下界最大流和最小流

文章作者:转载 更新时间:2023-02-17 10:00:53 阅读数量:96
文章标签:最大流最小流图论网络流dinic算法C++
本文摘要:这篇文章详细介绍了在C++环境下如何实现有源汇上下界条件下的最大流算法,采用Dinic算法求解。首先构建网络流模型,通过`add()`函数添加具有容量和下界属性的边,并利用广度优先搜索(bfs)寻找增广路径。核心函数`find()`负责在路径上增加流值,而`dinic()`则循环调用上述函数以逐步达到最大流。代码中还处理了源点S、汇点T以及节点的流量上下界约束,旨在解决具体网络流问题时找到满足上下界限制的最大流或最小流。
转载文章

本篇文章为转载内容。原文链接:https://blog.csdn.net/qq_52093121/article/details/126279694。

该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。

作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。

如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。

有汇源上下界最大流
有源汇上下界最大流最小流理解
题目
理解

#include<bits/stdc++.h>
using namespace std;
const int N=610,M=3e4,INF=0x3f3f3f3f;
int n,m,S,T;
int s,t;
int d[N];
int q[N],cur[N],h[N],ne[M],e[M],f[M],idx,A[N];void add(int a,int b,int c,int d)
{e[idx]=b,ne[idx]=h[a],f[idx]=d-c,h[a]=idx++;e[idx]=a,ne[idx]=h[b],f[idx]=0,h[b]=idx++;
}bool bfs()
{memset(d,-1,sizeof(d));int hh=0,tt=0;q[hh]=S,cur[S]=h[S],d[S]=0;while(hh<=tt){int t=q[hh++];for(int i=h[t];~i;i=ne[i]){int ver=e[i];if(d[ver]==-1&&f[i]){d[ver]=d[t]+1;cur[ver]=h[ver];if(ver==T) return true;q[++tt]=ver;}}}return false;
}int find(int u,int limit)
{if(u==T) return limit;int flow=0;for(int i=cur[u];~i&&flow<limit;i=ne[i]){cur[u]=i;int ver=e[i];if(d[ver]==d[u]+1&&f[i]){int t=find(ver,min(f[i],limit-flow));if(!t) d[ver]=-1;f[i]-=t,f[i^1]+=t,flow+=t;}}return flow;
}int dinic()
{int r=0;int flow;while(bfs()) while(flow=find(S,INF)) r+=flow;return r;
}int main()
{scanf("%d%d%d%d",&n,&m,&s,&t);S=0,T=n+1;memset(h,-1,sizeof(h));int tot=0;for(int i=1;i<=m;i++){int a,b,c,d;scanf("%d%d%d%d",&a,&b,&c,&d);add(a,b,c,d);A[a]-=c,A[b]+=c;}for(int i=1;i<=n;i++){if(A[i]>0) add(S,i,0,A[i]),tot+=A[i];else if(A[i]<0) add(i,T,0,-A[i]);}add(t,s,0,INF);if(dinic()<tot){puts("No Solution");}else{int res=f[idx-1];S=s,T=t;f[idx-1]=f[idx-2]=0;printf("%d\n",res+dinic());}return 0;
}

有汇源上下界最小流
题目

#include<bits/stdc++.h>
using namespace std;
const int N=1e6+10,M=5e6+10,INF=0x3f3f3f3f;
int n,m,S,T;
int s,t;
int d[N];
int q[N],cur[N],h[N],ne[M],e[M],f[M],idx,A[N];void add(int a,int b,int c,int d)
{e[idx]=b,ne[idx]=h[a],f[idx]=d-c,h[a]=idx++;e[idx]=a,ne[idx]=h[b],f[idx]=0,h[b]=idx++;
}bool bfs()
{memset(d,-1,sizeof(d));int hh=0,tt=0;q[hh]=S,cur[S]=h[S],d[S]=0;while(hh<=tt){int t=q[hh++];for(int i=h[t];~i;i=ne[i]){int ver=e[i];if(d[ver]==-1&&f[i]){d[ver]=d[t]+1;cur[ver]=h[ver];if(ver==T) return true;q[++tt]=ver;}}}return false;
}int find(int u,int limit)
{if(u==T) return limit;int flow=0;for(int i=cur[u];~i&&flow<limit;i=ne[i]){cur[u]=i;int ver=e[i];if(d[ver]==d[u]+1&&f[i]){int t=find(ver,min(f[i],limit-flow));if(!t) d[ver]=-1;f[i]-=t,f[i^1]+=t,flow+=t;}}return flow;
}int dinic()
{int r=0;int flow;while(bfs()) while(flow=find(S,INF)) r+=flow;return r;
}int main()
{scanf("%d%d%d%d",&n,&m,&s,&t);S=0,T=n+1;memset(h,-1,sizeof(h));int tot=0;for(int i=1;i<=m;i++){int a,b,c,d;scanf("%d%d%d%d",&a,&b,&c,&d);add(a,b,c,d);A[a]-=c,A[b]+=c;}for(int i=1;i<=n;i++){if(A[i]>0) add(S,i,0,A[i]),tot+=A[i];else if(A[i]<0) add(i,T,0,-A[i]);}add(t,s,0,INF);if(dinic()<tot){puts("No Solution");}else{int res=f[idx-1];S=t,T=s;f[idx-1]=f[idx-2]=0;printf("%d\n",res-dinic());}return 0;
}

本篇文章为转载内容。原文链接:https://blog.csdn.net/qq_52093121/article/details/126279694。

该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。

作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。

如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。

相关阅读
文章标题:[转载][洛谷P1082]同余方程

更新时间:2023-02-18
[转载][洛谷P1082]同余方程
文章标题:[转载]webpack优化之HappyPack实战

更新时间:2023-08-07
[转载]webpack优化之HappyPack实战
文章标题:[转载]oracle 同时更新多表,在Oracle数据库中同时更新两张表的简单方法

更新时间:2023-09-10
[转载]oracle 同时更新多表,在Oracle数据库中同时更新两张表的简单方法
文章标题:[转载][Unity] 包括场景互动与射击要素的俯视角闯关游戏Demo

更新时间:2024-03-11
[转载][Unity] 包括场景互动与射击要素的俯视角闯关游戏Demo
文章标题:[转载]程序员也分三六九等?等级差异,一个看不起一个!

更新时间:2024-05-10
[转载]程序员也分三六九等?等级差异,一个看不起一个!
文章标题:[转载]海贼王 动漫 全集目录 分章节 精彩打斗剧集

更新时间:2024-01-12
[转载]海贼王 动漫 全集目录 分章节 精彩打斗剧集
名词解释
作为当前文章的名词解释,仅对当前文章有效。
有源汇上下界最大流在图论和网络流问题中,有源汇上下界最大流是指在网络中存在一个源点(S)和一个汇点(T),每条边都有一个容量上限(即最大流量限制)以及一个下限(即最小流量需求或残留流量限制)。求解该问题的目标是在满足所有边的上下界约束条件下,找到从源点到汇点的最大流量。这个问题相较于传统的最大流问题更为复杂,因为它不仅要求流量尽可能大,还必须保证各条边的流量满足预设的最小值。
Dinic算法Dinic算法是一种用于解决网络流问题中的最大流问题的高效算法,由俄罗斯计算机科学家尤里·季林提出。该算法基于层次搜索思想,通过不断寻找并扩充增广路径来逐步增加网络中的流值,直到无法找到新的增广路径为止。在处理稀疏图时,其时间复杂度为O(V^2E),其中V代表顶点数量,E代表边的数量。文章中的代码片段正是基于Dinic算法实现的有源汇上下界最大流求解过程。
网络流残余网络在网络流理论中,残余网络是对原网络进行某种操作后得到的新网络,它反映了在当前流状态下,网络中可以进一步传输流量的能力。具体来说,在已知某个流方案的基础上,将每条正向边的剩余可传送流量以及反向边已经传送的流量作为新网络中对应边的容量,从而构建出残余网络。在求解有源汇上下界最大流问题时,需要不断地更新并分析残余网络,以寻找下一个增广路径并调整流值。
延伸阅读
作为当前文章的延伸阅读,仅对当前文章有效。
在探讨有源汇上下界最大流与最小流算法的实际应用和理论研究后,我们发现这一技术在网络优化、物流调度、电力系统等领域具有广泛应用价值。最近,我国电网公司成功运用改进的网络流算法解决了一项实际难题:在满足上下限供电需求的前提下,优化了跨区域电力调配,有效提升了电网运行效率。
延伸阅读一则来自《中国电力》杂志2022年最新报道,文章详细阐述了研究人员如何将有源汇上下界最大流模型应用于复杂电网场景中,通过Dinic算法的高效实现,实现了对输电线路容量限制以及各节点供电量约束条件下的最优电力分配方案。此外,报道还揭示了该算法在处理大规模数据和实时调度方面的优势,并进一步探讨了其在智能电网未来发展中的潜在作用。
另一方面,国际知名学术期刊《ACM Transactions on Algorithms》近期发布了一篇深度解读论文,作者深入剖析了有源汇上下界最大流问题的理论基础,并在此基础上提出了一种新的求解框架,不仅提高了原有Dinic算法的性能,还在特定条件下解决了最小流问题。这项研究为未来更复杂网络流问题的求解提供了新的理论工具和方法论指导,对于推动相关领域的发展具有深远意义。
总之,无论是从最新的科研进展还是现实世界的工程应用层面,有源汇上下界最大流与最小流算法都在持续展现出其强大的实用性与创新性,为我们理解和解决各类资源优化配置问题提供了强有力的数学工具和解决方案。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
renice priority_level -p pid - 更改已运行进程的优先级。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
可自定义logo的jQuery生成二维码插件 01-03 jquery每日签到日历插件 10-10 高度可定制的jQuery瀑布流网格布局插件 03-15 Consul中服务实例自动注销问题解析:健康检查、稳定性与Agent配置的影响及解决策略 01-22 怎么看mysql 的安装路径 12-31 jquery横向手风琴效果 12-23 蓝色数码电子产品销售HTML5网站模板 12-14 jQuery和CSS3汉堡包导航菜单打开动画特效 10-19 python模拟生存游戏 10-08 本次刷新还10个文章未展示,点击 更多查看。
jQuery.eraser-实现橡皮擦擦除功能的jquery插件 05-26 Netty中ChannelNotRegisteredException异常处理:理解原因与确保Channel注册状态的方法示例 05-16 响应式游戏开发类企业前端cms模板下载 05-02 精美的花甲美食网站HTML模板下载 03-09 soulmate粉色干净浪漫唯美婚礼单页响应式网站模板 03-07 Vue.js项目中proxyTable数据转发遭遇504错误:服务器响应时间与网络连接问题排查及解决方案 03-05 SpringCloud服务路由配置错误与失效:识别问题、排查步骤及组件解析这个涵盖了的核心内容,包括SpringCloud框架下的服务路由配置错误失效问题的识别,以及涉及到的服务注册中心、Gateway、Zuul等组件的功能解析和故障排查的具体步骤。同时,字数控制在了50个字以内,满足了要求。 03-01 css水平线长度设置 02-11 [转载]Proxy 、Relect、响应式 01-11 蓝色响应式软件营销代理公司网站静态模板 01-06 python正太分布校验 01-05
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"