news 2026/6/10 13:32:29

回溯法---旅行商问题

作者头像

张小明

前端开发工程师

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/6/6 23:25:29

5个实用的Python自动化脚本,提升效率必备

在日常工作与学习中&#xff0c;我们经常会遇到重复繁琐的任务&#xff0c;比如批量处理文件、自动整理数据、定时发送消息等。Python凭借其简洁的语法和丰富的第三方库&#xff0c;成为实现自动化的绝佳工具。本文将分享5个高频实用的Python自动化脚本&#xff0c;涵盖文件处理…

作者头像 李华
网站建设 2026/6/10 10:33:13

N端和C端序列测定

N端和C端序列测定N端和C端序列测定是指对蛋白质分子中氨基酸链的起始端&#xff08;N端&#xff09;和末端&#xff08;C端&#xff09;进行氨基酸序列分析的技术。蛋白质是由氨基酸通过肽键连接而成的长链分子&#xff0c;通常具有特定的生物功能。N端和C端序列决定了蛋白质的…

作者头像 李华
网站建设 2026/6/8 21:10:01

Docker镜像拉取难题破解:实用代理及配置指南

7牛AIPPT在版本发布过程中&#xff0c;常受困于Docker镜像拉取失败的问题&#xff0c;这一难题严重影响了发布效率。经过团队不懈探索与验证&#xff0c;我们整理出一批公共可用的Docker代理资源&#xff0c;结合不同环境的配置方法与使用技巧&#xff0c;形成这份实用指南&…

作者头像 李华
网站建设 2026/6/8 0:15:01

如何用EmotiVoice克隆自己的声音并生成播客?

如何用 EmotiVoice 克隆自己的声音并生成播客&#xff1f; 在内容创作的浪潮中&#xff0c;越来越多的人开始尝试制作属于自己的播客节目。但你是否也曾因为录制耗时、状态不稳定、语气单调而中途放弃&#xff1f;更别提一旦嗓子不舒服&#xff0c;整期节目的节奏都会被打乱。有…

作者头像 李华