- 1、本文档共21页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数学建模电子版 - 2008年南昌大学第五届数学建模竞赛
校园卡充值点的最优位置
[摘 要]本论文建立了校园卡充值点安排方案的最优化模型,为方便学生,让学生能够走最短的距离去充值点。在使各学院、楼栋、学生宿舍区到三个校园卡充值点的总路程最少的要求下,我们使用图论软件模拟计算出各学院、楼栋、学生宿舍区之间的最短距离,建立“0-1”模型,使用“启发式贪婪算法”,运用Lingo软件计算出三个最优点。最后在讨论分析后,对模型作出评价和改进,并结合实际情况对计算最优点的位置的方法进行改进。
模型:对题目中所给的各学院、楼栋、学生宿舍区之间的距离及路线,建立化折线为直线的模型。通过软件计算各点之间的最短距离,再用直线来代替折线连接任何两点,从而使得各点之间都是通过直线直接连接。结果见附录1。针对提出的问题,建立了最优化模型和 “0-1”模型,使用“启发式贪婪算法”方便的求出较理想的三个点,并进一步求出它们之间的路线和总的最短距离。为了得到最优解,我们运用Lingo软件计算出三个最优点:6区(医学实验楼)、12区(基础实验大楼)和21区(教学主楼),并得出最短距离为17.2公里。
本论文是从两栋楼之间的距离、楼栋分布的关系的变化分别对模型的灵敏度进行了分析。最后,结合实际情况,对模型进行了进一步的讨论,并给出了该进的目标函数,并提出了将该模型推广应用的领域。
关键词:图论软件 “0-1”模型 启发式贪婪算法 Lingo软件 整数线性规划
1问题的提出
校园卡为广大校园中人的生活、工作、教学提供了极大的便利。在就餐、乘车、购物中,有了校园卡,一切事情都变得畅通无阻、简单易行。校园卡已成为我校师生日常生活中不可缺少的随身携带的物品,不过,近日来校园卡管理部门也收到一些有关校园卡充值方面的意见和抱怨,有部分师生反映现有的三个校园卡充值点主要集中在本科生公寓i,j) 表示第i栋楼到第j栋楼的最短距离
flag_1(i)的含义为:当flag_1(i)=0时该建筑不是充值点,当flag_1(i)=1时表示该建筑为充值点.
flag_2(i,j)表示:当flag_2(i,j)=0时,i充值点未被j建筑选中;当flag_2(i,j)=1时i充值点被j建筑选中。
5 模型的建立与求解
从要解决的问题和所做出的假设出发,我们就问题(1)、问题(2)建立模型。
模型 化折线为直线模型和0-1模型
本模型从任何两栋楼之间的距离和路线考虑,先使用图论软件,算出任意两栋楼之间的最短距离,并列出表格(见附录1)。由于有些楼栋之间不是直接用路线连接,但是我们这里计算出了它们之间的最短距离,所以可以假想一条长度等于这个最短距离的路线将这两栋楼连接起来。从而解决了问题(1)。而后我们使用“启发式贪婪算法”方便的求出较理想的三个点,并进一步求出它们之间的路线和总的最短距离。因为贪婪算法只是考虑局部的最优,并不一定能够得出整体的最优结果。为了得到最优解,我们建立0-1模型,应用LINGO软件解出了充值点所在的位置,并求出各楼栋到三充值点的最短距离。
1.对问题的分析与求解
对于本问题,首先在两建筑物之间求出它们的最短距离。然后在此基础上,我们建立了要满足各建筑到各充值点的路程最短。
方法1:“启发式贪婪算法”
依据前面对问题所做的分析,再结合图中所给的各栋楼的位置关系,我们首先排除位于学校边缘的十栋楼,它们是:青年教师宿舍区、国际学术交流中心、医学院教学大楼、本科生公寓A区、本科生公寓B区、学工楼、本科生公寓C区、校医院、艺术楼、办公楼。我们先假设剩余的18栋楼都各设一个充值点,然后分别去掉一个楼栋的充值点,分别计算到剩余17个充值点的最短路程,比较它们的路程并去掉路程最小情况下的那栋楼(即排除该栋楼为充值点);此时剩余17充值点。按照以上方法,依次取点直到只剩3个为止。我们根据此思路用Microsoft visual C++6.0编程(程序和运行结果见附录2),让计算机自动求解,得出较理想的三个位置,在根据这三个位置继续编程求出最短路程并确定具体路径。
根据此方法得出的三个较理想位置是医学实验楼,图书馆,综合楼。最短路程为18.1.
具体路径见附录3.
由于此方法求解时只考虑局部最优,所以该解并不一定是最优解,但此方法思路简单,很容易求出较为理想的位置。
为了进一步求出最优解,我们采用方法2 ,使用LINGO软件编程求解。
方法2:用LINGO软件编程求解
依据前面对问题所做的分析,为了设计便于操作,可根据两建筑之间最短距离distance(i,j)、充值点flag_1(i)以及i 充值点被j 建筑选中flag_2(i,j),建立以下模型来求相关量。
最短路程
min S=
对于一个确定的建筑物building(i),
文档评论(0)