ImageVerifierCode 换一换
格式:DOCX , 页数:15 ,大小:196.85KB ,
资源ID:9622227      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/9622227.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(运筹学指派问题的匈牙利法实验报告.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

运筹学指派问题的匈牙利法实验报告.docx

1、运筹学指派问题的匈牙利法实验报告运 筹 学课程设计报告专业: 班级: 学号: 姓名: 2012年6月20日一、 题目。二、 算法思想。三、 算法步骤。四、 算法源程序。五、 算例和结果。六、 结论与总结。一、 题目:匈牙利法求解指派问题。二、 算法思想。匈牙利解法的指派问题最优解的以下性质:设指派问题的系数矩阵为C=,若将C的一行(或列)各元素分别减去一个常数k(如该行或列的最小元素),则得到一个新的矩阵C=。那么,以C位系数矩阵的指派问题和以C位系数矩阵的原指派问题有相同最优解。由于系数矩阵的这种变化不影响约束方程组,只是使目标函数值减少了常数k,所以,最优解并不改变。必须指出,虽然不比要求

2、指派问题系数矩阵中无负元素,但在匈牙利法求解指派问题时,为了从以变换后的系数矩阵中判别能否得到最优指派方案,要求此时的系数矩阵中无负元素。因为只有这样,才能从总费用为零这一特征判定此时的指派方案为最优指派方案。三、 算法步骤。(1)变换系数矩阵,使各行和各列皆出现零元素。各行及各列分别减去本行及本列最小元素,这样可保证每行及每列中都有零元素,同时,也避免了出现负元素。(2)做能覆盖所有零元素的最少数目的直线集合。因此,若直线数等于n,则以可得出最优解。否则,转第(3)步。对于系数矩阵非负的指派问题来说,总费用为零的指派方案一定是最优指派方案。在第(1)步的基础上,若能找到n个不同行、不同列的零

3、元素,则对应的指派方案总费用为零,从而是最优的。当同一行(或列)上有几个零元素时,如选择其一,则其与的零元素就不能再被选择,从而成为多余的。因此,重要的是零元素能恰当地分布在不同行和不同列上,而并在与它们的多少。但第(1)步并不能保证这一要求。若覆盖所有零元素的最少数目的直线集合中的直线数目是n,则表明能做到这一点。此时,可以从零元素的最少的行或列开始圈“0”,每圈一个“0”,同时把位于同行合同列的其他零元素划去(标记为),如此逐步进行,最终可得n个位于不同行、不同列的零元素,他们就对应了最优解;若覆盖所有零元素的最少数目的直线集合中的元素个数少于n,则表明无法实现这一点。需要对零元素的分布做

4、适当调整,这就是第(3)步。(3) 变换系数矩阵,是未被直线覆盖的元素中出现零元素。回到第(2)步。在未被直线覆盖的元素中总有一个最小元素。对未被直线覆盖的元素所在的行(或列)中各元素都减去这一最小元素,这样,在未被直线覆盖的元素中势必会出现零元素,但同时却又是以被直线覆盖的元素中出现负元素。为了消除负元素,只要对它们所在的列(或行)中个元素都加上这一最小元素(可以看作减去这一最小元素的相反数)即可。四、 算法源程序。#include#include#define m 5int input(int Mmm) int i,j; for(i=0;im;i+) cout请输入系数矩阵第i+1行元素:

5、endl; for(j=0;jMij; cout系数矩阵为:endl; for(i=0;im;i+) for(j=0;jm;j+) coutMijt; coutendl; return Mmm;int convert(int Mmm) int xm,ym; int i,j; for(i=0;im;i+) xi=Mi0; for(j=1;jm;j+) if(Mijxi) xi=Mij; for(i=0;im;i+) for(j=0;jm;j+) Mij-=xi; for(j=0;jm;j+) yj=M0j; for(i=0;im;i+) if(Mijyj) yj=Mij; for(i=0;im;

6、i+) for(j=0;jm;j+) Mij-=yj; cout对系数矩阵各行各列进行变换得:endl; for(i=0;im;i+) for(j=0;jm;j+) coutMijt; coutendl; return Mmm;int exchange(int Mmm) int i,j,n; cout进行行变换输入0,进行列变换输入其他任意键:n; if(n=0) cout分别输入要变换的行及该行未覆盖元素中最小元素:endl; else cout分别输入要变换的列及该列的最小元素:ab; for(j=0;jm;j+) if(n=0) Ma-1j-=b; else Mja-1-=b; cout

7、变换后的矩阵:endl; for(i=0;im;i+) for(j=0;jm;j+) coutMijt; coutendl; return Mmm; void main() int Mmm; cout endl; while(true) coutendl; cout 菜单 endlendl; cout 1.系数矩阵输入 endl; cout 2.初始变换 endl; cout 3.行列变换 endl; cout 4.退出 endl; cout*endlendl; int n; coutn; switch(n) case 1: input(M);break; case 2: convert(M)

8、;break; case 3: exchange(M);break; case 4: cout谢谢使用!endl; exit(0);break; default: cout输入有误!请重新输入!endl; 五、 算例和结果。例412 今有甲、乙、丙、丁4个人去完成5项任务。每人完成各项任务所需的时间如表411所示。由于任务数多于人数,故规定其中有一人可兼完成两项任务,其余三人各完成一项任务。是确定总花费时间为最小的指派方案。(课本P113)表411 任务人ABCDE甲2529314137乙3938262033丙3427284032丁2442362345假设第5个人是戊,他完成各项任务的时间取甲

9、、乙、丙、丁中的最小者,构造表412。表412 任务人ABCDE甲2529314137乙3938262033丙3427284032丁2442362345戊2427262032由表412可得到系数矩阵C1、将系数矩阵C输入程序。2、对系数矩阵各行各列减去最小元素,即程序中的初始变换。3、进行行变换 4、进行列变换 6、再次进行行变换 7、再次进行列变换 此时,已经不能用少于五根直线覆盖零元素,故此时为最优指派方案。最优指派方案是:甲做B,乙做C,丙做E,丁做A,戊做D,由于戊(虚拟的人)完成D的时间与乙相同,实际上最优指派方案是:乙完成C和D,甲、丙、丁分别完成B,E,A,总计时间为131。六、

10、 结论和总结。匈牙利法解指派问题,其步骤简单易懂,操作起来也不难,可是由于计算量实在太大很容易出错,故利用程序来完成对系数矩阵的化简变换是再好不过的。只要确定输入,以及找出的覆盖集合无误,则计算结果就不会出错。由于时间仓促,我编的程序还有许多不足之处,比如说:在输入系数矩阵之前,需要事先定义二维数组的行及列。针对这个问题我尝试了好几次,也没有解决。查了一些资料,好像可以通过动态分配二维数组的空间大小来实现二维数组行和列的输入。本来我想实现程序对系数矩阵零元素的直线覆盖功能的,可操作起来实在太难,故改为手动操作。通过这次课程设计,我不仅对运筹学的知识进行了巩固,也发觉到了编程对数学的强大辅助功能。利用它可以解决好多数学问题,大大节省了时间及精力。学好数学和计算机是今后就业的重要筹码。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1