用分支限界算法解决旅行商问题.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
用分支限界算法解决旅行商问题,分支限界算法,回溯算法和分支限界法,分支限界算法原理,旅行商问题分支限界,分支限界法旅行商,分支限界法,优先队列式分支限界法,分支限界,分支限界法01背包

//求解旅行商问题的分枝限界算法 #include stdio.h #include stdlib.h #include math.h #define TRUE (1) #define FALSE (0) #define MAX_CITIES (10) #define INFINITY??(999) #define I INFINITY typedef int bool; /* 定义边结构 */ typedef struct _EDGE { ? ? ? ? int head; ? ? ? ? int tail; } EDGE; /* 定义路径结构 */ typedef struct _PATH { ? ? ? ? EDGE edge[MAX_CITIES]; ? ? ? ? int??edgesNumber; } PATH; /* 定义花费矩阵结构 */ typedef struct _MATRIX { ? ? ? ? int distance[MAX_CITIES][MAX_CITIES]; ? ? ? ? int citiesNumber; } MATRIX; /* 定义树结点 */ typedef struct _NODE { ? ? ? ? int bound;? ? ? ? /* 相应于本结点的花费下界 */ ? ? ? ? MATRIX matrix;? ? ? ? /* 当前花费矩阵 */ ? ? ? ? PATH path;? ? ? ? /* 已经选定的边 */ ? ? ? ? struct _NODE* left;? ? ? ? /* 左枝 */ ? ? ? ? struct _NODE* right;? ? ? ? /* 右枝 */ } NODE; int Simplify(MATRIX*); EDGE SelectBestEdge(MATRIX); MATRIX LeftNode(MATRIX, EDGE); MATRIX RightNode(MATRIX, EDGE, PATH); PATH AddEdge(EDGE, PATH); PATH BABA(NODE); PATH MendPath(PATH, MATRIX); int MatrixSize(MATRIX, PATH); void ShowMatrix(MATRIX); void ShowPath(PATH, MATRIX); main() { ? ? ? ? PATH path; ? ? ? ? NODE root = { ? ? ? ? ? ? ? ? 0, /* 花费下界 */ ? ? ? ? ? ? ? ? {{{I, 1, 2, 7, 5}, /* 花费矩阵 */ ? ? ? ? ? ? ? ?? ?{1, I, 4, 4, 3}, ? ? ? ? ? ? ? ?? ?{2, 4, I, 1, 2}, ? ? ? ? ? ? ? ?? ?{7, 4, 1, I, 3}, ? ? ? ? ? ? ? ?? ?{5, 3, 2, 3, I}}, 5}, /* 城市数目 */ ? ? ? ? ? ? ? ? {{0}, 0}, /* 经历过的路径 */ ? ? ? ? ? ? ? ? NULL, NULL /* 左枝与右枝 */ ? ? ? ? }; ? ? ? ? /* 归约,建立根结点 */ ? ? ? ? root.bound += Simplify(root.matrix); ? ? ? ? /* 进入搜索循环 */ ? ? ? ? path = BABA(root); ? ? ? ? ShowPath(path, root.matrix); return 0; } /* * 算法主搜索函数,Branch-And-Bound Algorithm Search *? ?? ?? ?? ? root 是当前的根结点,已归约,数据完善 */ PATH BABA(NODE root) { ? ? ? ? int i; ? ? ? ? static int minDist = INFINITY; ? ? ? ? static PATH minPath; ? ? ? ? EDGE selectedEdge; ? ? ? ? NODE *left, *right; ? ? ? ? puts(Current Root:\n------------); ? ? ? ? ShowMatrix(root.matrix); ? ? ? ? printf(Root Bound:%d\n, root.bound); ? ? ? ? /* 如果当前矩阵大小为2,说明还有两条边没有选,而这两条边必定只能有一种组合, ? ? ? ??

文档评论(0)

tianma2015 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档