news 2026/5/1 10:13:36

回溯法---旅行商问题

作者头像

张小明

前端开发工程师

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/5/1 8:16:47

Vim插件管理器终极指南:从零开始快速掌握VAM

Vim插件管理器终极指南&#xff1a;从零开始快速掌握VAM 【免费下载链接】vim-addon-manager manage and install vim plugins (including their dependencies) in a sane way. If you have any trouble contact me. Usually I reply within 24 hours 项目地址: https://gitc…

作者头像 李华
网站建设 2026/5/1 7:57:42

Grafana中文界面定制解决方案

Grafana中文界面定制解决方案 【免费下载链接】grafana-chinese grafana中文版本 项目地址: https://gitcode.com/gh_mirrors/gr/grafana-chinese 在数据可视化领域&#xff0c;Grafana作为业界领先的开源监控解决方案&#xff0c;其强大的仪表盘功能和灵活的插件体系深…

作者头像 李华
网站建设 2026/5/1 8:01:23

计算机毕业设计springboot医药垃圾分类管理系统 基于SpringBoot的医疗废弃物智能分类平台 医药固废全流程信息管理系统

计算机毕业设计springboot医药垃圾分类管理系统iod0rd94 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。随着医药产业规模扩大&#xff0c;过期药品、一次性耗材、临床残余药剂等…

作者头像 李华
网站建设 2026/5/1 9:11:10

生物标志物(Biomarker)基础科普

一、生物标志物&#xff08;Biomarker&#xff09;的核心定义生物标志物&#xff08;Biomarker&#xff09;是可标记系统、器官、组织、细胞及亚细胞结构或功能改变&#xff0c;或潜在改变的生化指标&#xff0c;其应用范围覆盖生物医学多个领域。在疾病研究领域&#xff0c;它…

作者头像 李华
网站建设 2026/5/1 8:45:54

FunASR语音识别终极指南:从零开始快速构建AI语音应用

FunASR语音识别工具作为开源领域的明星项目&#xff0c;正在改变人们处理语音数据的方式。无论你是开发者、产品经理还是技术爱好者&#xff0c;都能通过这个强大的工具包轻松实现语音转文字功能。&#x1f3af; 【免费下载链接】FunASR A Fundamental End-to-End Speech Recog…

作者头像 李华