匈牙利算法匈牙利算法在计算机C++语言编程中怎么应用?

匈牙利算法  时间:2021-07-16  阅读:()

能不能把你的基于matlab的匈牙利算法的代码发给我啊!谢谢了

unction [z,an]=fenpei(marix) %输入效率矩阵 marix 为方阵; %若效率矩阵中有 M,则用一充分大的数代替; %输出z为最优解,an为 最优分配矩阵; a=marix; b=a; %确定矩阵维数 s=length(a); %确定矩阵行最小值,进行行减 ml=min(a’); for i=1:s a(i,:)=a(i,:)-ml(i); end %确定矩阵列最小值,进行列减 mr=min(a); for j=1:s a(:,j)=a(:,j)-mr(j); end % start working num=0; while(num~=s) %终止条件是“(0)”的个数与矩阵的维数相同 %index用以标记矩阵中的零元素,若a(i,j)=0,则index(i,j)=1,否则index(i,j)=0 index=ones(s); index=a&index; index=~index; %flag用以标记划线位,flag=0 表示未被划线, %flag=1 表示有划线过,flag=2 表示为两直线交点 %an用以记录 a 中“(0)”的位置 %循环后重新初始化flag,an flag = zeros(s); an = zeros(s); %一次循环划线全过程,终止条件是所有的零元素均被直线覆盖, %即在flag>0位,index=0 while(sum(sum(index))) %按行找出“(0)”所在位置,并对“(0)”所在列划线, %即设置flag,同时修改index,将结果填入an for i=1:s t=0; l=0; for j=1:s if(flag(i,j)==0&&index(i,j)==1) l=l+1; t=j; end end if(l==1) flag(:,t)=flag(:,t)+1; index(:,t)=0; an(i,t)=1; end end %按列找出“(0)”所在位置,并对“(0)”所在行划线, %即设置flag,同时修改index,将结果填入an for j=1:s t=0; r=0; for i=1:s if(flag(i,j)==0&&index(i,j)==1) r=r+1; t=i; end end if(r==1) flag(t,:)=flag(t,:)+1; index(t,:)=0; an(t,j)=1; end end end %对 while(sum(sum(index))) %处理过程 %计数器:计算an中1的个数,用num表示 num=sum(sum(an)); % 判断是否可以终止,若可以则跳出循环 if(s==num) break; end %否则,进行下一步处理 %确定未被划线的最小元素,用m表示 m=max(max(a)); for i=1:s for j=1:s if(flag(i,j)==0) if(a(i,j)<M) m=a(i,j); end end end end %未被划线,即flag=0处减去m;线交点,即flag=2处加上m for i=1:s for j=1:s if(flag(i,j)==0) a(i,j)=a(i,j)-m; end if(flag(i,j)==2) a(i,j)=a(i,j)+m; end end end end %对while(num~=s) %计算最优(min)值 zm=an.*b; z=sum(sum(zm));

什么是匈牙利法?

匈牙利法是求解及小型(优化方向为极小)指派问题的一种方法,这种方法最初由w.w.kuhn提出,后经改进而形成,解法基于匈牙利数学家D.K?nig给出的一个定理而得名。

什么是匈牙利算法

谈匈牙利算法自然避不开Hall定理,即是:对于二部图G,存在一个匹配M,使得X的所有顶点关于M饱和的充要条件是:对于X的任意一个子集A,和A邻接的点集为T(A),恒有: │T(A)│ >= │A│ 匈牙利算法是基于Hall定理中充分性证明的思想,其基本步骤为: 1.任给初始匹配M; 2.若X已饱和则结束,否则进行第3步; 3.在X中找到一个非饱和顶点x0,作V1 ← {x0}, V2 ← Φ; 4.若T(V1) = V2则因为无法匹配而停止,否则任选一点y ∈T(V1)V2; 5.若y已饱和则转6,否则做一条从x0 →y的可增广道路P,M←M?E(P),转2; 6.由于y已饱和,所以M中有一条边(y,z),作 V1 ← V1 ∪{z}, V2 ← V2 ∪ {y}, 转4; 设数组up[1..n] --- 标记二分图的上半部分的点。

down[1..n] --- 标记二分图的下半部分的点。

map[1..n,1..n] --- 表示二分图的上,下部分的点的关系。

True-相连, false---不相连。

over1[1..n],over2[1..n] 标记上下部分的已盖点。

use[1..n,1..n] - 表示该条边是否被覆盖 。

首先对读入数据进行处理 ,对于一条边(x,y) ,起点进集合up,终点进集合down。

标记map中对应元素为true。

1. 寻找up中一个未盖点 。

2. 从该未盖点出发 ,搜索一条可行的路线 ,即由细边出发, 由细边结束, 且细粗交错的路线 。

3. 若找到 ,则修改该路线上的点所对应的over1,over2,use的元素。

重复步骤1。

4. 统计use中已覆盖的边的条数total,总数n减去total即为问题的解。

匈牙利算法在计算机C++语言编程中怎么应用?

匈牙利算法是图论中完成二分图匹配的经典算法之一.输入排队的Crossbar调度算法是以获得交换机的输入端口和输出端口最大匹配,从而得到高吞吐量为目的.因而在调度算法理论研究中应用了二分图最大匹配的Maximum Size Matching(MSM)和 Maximum Weight Matching(MWM)算法成为各种调度算法性能的评价标准.文中介绍了匈牙利算法在输入排队调度算法仿真中的应用,并且得出相应典型算法的性能仿真曲线,从而为进一步研究调度算法打下理论基础.

享有云:美国BGP云服务器低至20元/月起,首月打折;香港2核2G2M仅50元/月起

享有云怎么样?享有云是一家新的国内云服务器商家,目前提供国内、香港及海外地区的云服务器,拥有多线路如:BGP线路、CN2线路、高防等云服务器,并且提供稳定、安全、弹性、高性能的云端计算服务,实时满足您的多样性业务需求。目前,美国bgp云服务器,5M带宽,低至20元/月起,270元/年起,首月打折;香港2核2G2M仅50元/月起,450元/年起!点击进入:享有云官方网站地址享有云优惠活动:一、美国B...

iON Cloud:新加坡cn2 gia vps/1核/2G内存/25G SSD/250G流量/10M带宽,$35/月

iON Cloud怎么样?iON Cloud升级了新加坡CN2 VPS的带宽和流量最低配的原先带宽5M现在升级为10M,流量也从原先的150G升级为250G。注意,流量也仅计算出站方向。iON Cloud是Krypt旗下的云服务器品牌,成立于2019年,是美国老牌机房(1998~)krypt旗下的VPS云服务器品牌,主打国外VPS云服务器业务,均采用KVM架构,整体性能配置较高,云服务器产品质量靠...

TTcloud(月$70)E3-1270V3 8GB内存 10Mbps带宽 ,日本独立服务器

关于TTCLOUD服务商在今年初的时候有介绍过一次,而且对于他们家的美国圣何塞服务器有过简单的测评,这个服务商主要是提供独立服务器业务的。目前托管硬件已经达到5000台服务器或节点,主要经营圣何塞,洛杉矶以及日本东京三个地区的数据中心业务。这次看到商家有推出了新上架的日本独立服务器促销活动,价格 $70/月起,季付送10Mbps带宽。也可以跟进客户的需求进行各种DIY定制。内存CPU硬盘流量带宽价...

匈牙利算法为你推荐
saltstacksaltwater room是什么意思?g2g吉他的效果器的名称是什么意思?(G1G,G2G等等)图片地址怎么获得图片地址查字网拐字换什么偏旁 成新字mindmanager破解版请给个Mindjet MindManager PRO 15的正式版丁奇海贼王里“D”的意思是什么?弹幕网站A站B站网址是什么,国内很出名嗎?有什么网站特点..暴力破解密码8位密码暴力破解要多久新手怎么制作表格怎么制作表格?疫苗之王被称为免疫之王的产品
漂亮qq空间 virpus 外国服务器 圣迭戈 国外php空间 天互数据 免费mysql vip购优汇 ftp教程 百兆独享 工作站服务器 老左正传 服务器托管什么意思 空间技术网 如何注册阿里云邮箱 闪讯官网 带宽租赁 网站加速软件 smtp服务器地址 杭州电信宽带优惠 更多