求最小费用最大流算法的MATLAB-程序代码.doc

求最小费用最大流算法的MATLAB-程序代码.doc

ID:52812694

大小:26.50 KB

页数:1页

时间:2020-03-30

求最小费用最大流算法的MATLAB-程序代码.doc_第1页
资源描述:

《求最小费用最大流算法的MATLAB-程序代码.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、求最小费用最大流算法的MATLAB程序代码如下(算例):n=5;C=[0151600000131401101700000800000];%弧容量b=[0410000061020300000200000];%弧上单位流量的费用wf=0;wf0=Inf;%wf表示最大流量,wf0表示预定的流量值for(i=1:n)for(j=1:n)f(i,j)=0;end;end%取初始可行流f为零流while(1)for(i=1:n)for(j=1:n)if(j~=i)a(i,j)=Inf;end;end;end%构造有向赋权图for(i=1:n)for(j=1:n)if(C(i,j)>0&f

2、(i,j)==0)a(i,j)=b(i,j);elseif(C(i,j)>0&f(i,j)==C(i,j))a(j,i)=-b(i,j);elseif(C(i,j)>0)a(i,j)=b(i,j);a(j,i)=-b(i,j);end;end;endfor(i=2:n)p(i)=Inf;s(i)=i;end%用Ford算法求最短路,赋初值for(k=1:n)pd=1;%求有向赋权图中vs到vt的最短路for(i=2:n)for(j=1:n)if(p(i)>p(j)+a(j,i))p(i)=p(j)+a(j,i);s(i)=j;pd=0;end;end;endif(pd)brea

3、k;end;end%求最短路的Ford算法结束if(p(n)==Inf)break;end%不存在vs到vt的最短路,算法终止.注意在求最小费用最大流时构造有向赋权图中不会含负权回路,所以不会出现k=ndvt=Inf;t=n;%进入调整过程,dvt表示调整量while(1)%计算调整量if(a(s(t),t)>0)dvtt=C(s(t),t)-f(s(t),t);%前向弧调整量elseif(a(s(t),t)<0)dvtt=f(t,s(t));end%后向弧调整量if(dvt>dvtt)dvt=dvtt;endif(s(t)==1)break;end%当t的标号为vs时,终止计

4、算调整量t=s(t);end%继续调整前一段弧上的流fpd=0;if(wf+dvt>=wf0)dvt=wf0-wf;pd=1;end%如果最大流量大于或等于预定的流量值t=n;while(1)%调整过程if(a(s(t),t)>0)f(s(t),t)=f(s(t),t)+dvt;%前向弧调整elseif(a(s(t),t)<0)f(t,s(t))=f(t,s(t))-dvt;end%后向弧调整if(s(t)==1)break;end%当t的标号为vs时,终止调整过程t=s(t);endif(pd)break;end%如果最大流量达到预定的流量值wf=0;for(j=1:n)wf

5、=wf+f(1,j);end;end%计算最大流量zwf=0;for(i=1:n)for(j=1:n)zwf=zwf+b(i,j)*f(i,j);end;end%计算最小费用f%显示最小费用最大流wf%显示最小费用最大流量zwf%显示最小费用,程序结束

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。