news 2026/7/4 21:38:55

回溯法---旅行商问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
回溯法---旅行商问题
  • 程语言Python
  • 难度 中等

问题描述:

给定一组城市和每对城市之间的距离,找到一条最短路径,使得一位旅行商从一个城市出发后,恰好访问每个城市一次,并最终返回出发的城市。

问题特点:

完整性:

旅行商需要访问所有给定的城市。

唯一性:

每个城市只能访问一次(除了起始城市,它既是起点也是终点)。

闭合性:

旅行路线必须形成一个环路,即旅行商最后要回到出发点。

最优性:

寻找的路径应该是所有可能路径中最短的一条。

数学表示:
测试用例:

ifname== "main": import sys NoEdge = sys.maxsize a = [[0,0,0,0,0,0],[0,NoEdge,10,NoEdge,4,12],[0,10,NoEdge,15,8,5],[0,NoEdge,15,NoEdge,7,30],[0,4,8,7,NoEdge,6],[0,12,5,30,6,NoEdge]] n = len(a) x = [i for i in range(n)] bestx =None bestc = NoEdge cc = 0 backtrack(2)#第一个城市固定,所以从第二层开始搜索 print("最短路径长度为:", bestc) print("最短路径为:", bestx)

源码:
import sys def backtrack(t): global cc, bestc, bestx, x, a, n, NoEdge # 递归终止:遍历完所有城市,计算返回起点的总距离 if t == n: # 总距离 = 当前路径长度 + 最后一个城市回到起点的距离 total = cc + a[x[n-1]][x[1]] if total < bestc: bestc = total # 深拷贝当前路径,避免后续修改影响最优解 bestx = x.copy() else: # 遍历t到n-1的城市,生成排列(选择下一个要访问的城市) for i in range(t, n): # 交换x[t]和x[i],选择第i个城市作为当前层的选择 x[t], x[i] = x[i], x[t] # 剪枝:当前路径长度 + 上一个城市到当前城市的距离 < 最优解,才继续搜索 if cc + a[x[t-1]][x[t]] < bestc: # 更新当前路径长度 cc += a[x[t-1]][x[t]] # 递归搜索下一层 backtrack(t + 1) # 回溯:恢复当前路径长度 cc -= a[x[t-1]][x[t]] # 回溯:恢复x的顺序 x[t], x[i] = x[i], x[t] if __name__ == "__main__": NoEdge = sys.maxsize # 表示无路径(本题中未用到,仅占位) # 距离矩阵:a[i][j]表示城市i到城市j的距离,索引0无意义,有效城市为1-5 a = [ [0, 0, 0, 0, 0, 0], [0, NoEdge, 10, NoEdge, 4, 12], [0, 10, NoEdge, 15, 8, 5], [0, NoEdge, 15, NoEdge, 7, 30], [0, 4, 8, 7, NoEdge, 6], [0, 12, 5, 30, 6, NoEdge] ] n = len(a) # n=6,对应城市索引0(无效)、1、2、3、4、5 x = [i for i in range(n)] # 当前路径,初始为[0,1,2,3,4,5] bestx = None # 最优路径 bestc = NoEdge # 最优路径长度,初始为极大值 cc = 0 # 当前路径长度 backtrack(2) # 第一个城市(x[1]=1)固定,从第2层开始搜索 print("最短路径长度为:", bestc) print("最短路径为:", bestx)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/4 0:17:47

Minecraft Bedrock启动器技术实现与优化指南

Bedrock启动器作为Minecraft基岩版的专业管理工具&#xff0c;通过模块化架构和智能化算法为玩家提供高效的游戏版本管理与性能调优解决方案。本文将从技术实现角度深入解析启动器的核心能力、部署方案及优化策略。 【免费下载链接】BedrockLauncher 项目地址: https://gitc…

作者头像 李华
网站建设 2026/7/3 6:24:37

MegSpot开源项目完整教程:从入门到精通

MegSpot开源项目完整教程&#xff1a;从入门到精通 【免费下载链接】MegSpot MegSpot是一款高效、专业、跨平台的图片&视频对比应用 项目地址: https://gitcode.com/gh_mirrors/me/MegSpot MegSpot是一款功能强大的开源项目&#xff0c;专为研究人员和开发者设计的高…

作者头像 李华
网站建设 2026/6/30 9:36:09

XposedRimetHelper位置服务功能深度解析:提升钉钉使用体验

功能亮点&#xff1a;扩展位置服务边界 【免费下载链接】XposedRimetHelper Xposed 钉钉辅助模块&#xff0c;暂时实现模拟位置。 项目地址: https://gitcode.com/gh_mirrors/xp/XposedRimetHelper XposedRimetHelper作为一款基于Xposed框架的钉钉增强模块&#xff0c;其…

作者头像 李华
网站建设 2026/7/3 14:20:01

深度解锁Windows隐藏功能:ViVeTool GUI使用全攻略

深度解锁Windows隐藏功能&#xff1a;ViVeTool GUI使用全攻略 【免费下载链接】ViVeTool-GUI Windows Feature Control GUI based on ViVe / ViVeTool 项目地址: https://gitcode.com/gh_mirrors/vi/ViVeTool-GUI 在Windows系统的深处&#xff0c;隐藏着大量未被官方启用…

作者头像 李华
网站建设 2026/7/3 10:40:05

如何快速配置Jellyfin Bangumi插件:新手3分钟上手教程

还在为Jellyfin中的番剧元数据不全而烦恼吗&#xff1f;Jellyfin Bangumi插件帮你完美解决&#xff01;这款免费开源插件专门为中文用户打造&#xff0c;能够自动从Bangumi获取高质量的中文番剧元数据&#xff0c;并实现播放进度自动同步到Bangumi账号。无论是动画剧集、电影还…

作者头像 李华
网站建设 2026/7/2 5:30:56

KOReader终极完整指南:免费打造专业级电子书阅读体验

KOReader终极完整指南&#xff1a;免费打造专业级电子书阅读体验 【免费下载链接】koreader An ebook reader application supporting PDF, DjVu, EPUB, FB2 and many more formats, running on Cervantes, Kindle, Kobo, PocketBook and Android devices 项目地址: https://…

作者头像 李华