- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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 INFINITYtypedef 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,说明还有两条边没有选,而这两条边必定只能有一种组合,? ? ? ??
您可能关注的文档
最近下载
- 变电设备检修工职业认证隔离开关主刀闸工作原理GW23B-126型隔离开关说明书.pdf VIP
- QB1696-1993啤酒麦芽附录A比重与浸出物含量对照表.pdf VIP
- 《先兆流产》课件.ppt VIP
- (2025秋新版)部编版二年级语文上册全册PPT课件.pptx
- 清洁设备操作及日常保养标准作业规程.doc VIP
- 2025年高中政治必修同步课时练 必修一 第一课 周练过关(一).pdf VIP
- 2025年中考备考:人教版九年级物理上册全书课后练习答案.docx VIP
- 班级卫生值日表模板.xlsx VIP
- 深基坑开挖及支护施工专项方案.doc VIP
- 学习2025《初中生自我介绍》专题课件ppt.pptx VIP
文档评论(0)