热门标签 | HotTags
当前位置:  开发笔记 > 人工智能 > 正文

旅行商问题(深度优先搜索回溯法排列树)

1.问题描述:有一个推销员,要到n个城市推销商品,他要找出一个包含所有n个城市的具有最短路程的环路。(最后回到原来的城市)示例:从城市1出发经过所有城市后回到城市1,要使总路程最短。2.算法设计:给定

1.问题描述:

有一个推销员,要到n个城市推销商品,他要找出一个包含所有n个城市的具有最短路程的环路。(最后回到原来的城市)

示例:从城市1出发经过所有城市后回到城市1,要使总路程最短。

2.算法设计:

给定n个城市的无向带权图G(V,E),顶点代表城市,权值代表城市之间的距离。若城市之间没有路径,则距离为无穷。

城市之间的距离存放在二维数组g[][]中。

从城市1出发,先到临近城市2,将走过的路程存放在变量 cl 中。

bestl代表当前找到的一种最短路径长度。如走法:1-2-3-4-5-1

显然,向城市深处走时,cl只会增加。因此当cl>bestl时,不必再往深处走。

限界条件为cl

3.代码:

#include
using namespace std;
#define MAX 1000
int g[100][100],x[100],bestx[100];

int cl=0,bestl=MAX,n;

void Traveling(int t)
{
int j;
if(t>n) //到达叶子结点
{
if(g[x[n]][1]!=-1 && (cl+g[x[n]][1] {
for(j=1; j<=n; j++)
bestx[j]=x[j];
bestl=cl+g[x[n]][1];
}
}
else //没有到达叶子结点
{
for(j=t; j<=n; j++)//搜索扩展结点的左右分支,即所有与当前所在城市临近的城市
{
if(g[x[t-1]][x[j]]!=-1 && (cl+g[x[t-1]][x[j]] {
swap(x[t],x[j]); //保存要去的第t个城市到x[t]中
cl+=g[x[t-1]][x[t]]; //路线长度增加
Traveling(t+1); //搜索下一个城市
cl-=g[x[t-1]][x[t]];
swap(x[t],x[j]);
}
}
}
}
int main()
{
int i,j;
cout<<"请输入一共有几个城市:"< cin>>n;
cout<<"请输入城市之间的距离"<
for(i=1; i<=n; i++)
for(j=1; j<=n; j++)
cin>>g[i][j];

for(i=1; i<=n; i++)
{
x[i]=i;
bestx[i]=0;
}

Traveling(2);
cout<<"城市路线:"< for(i=1; i<=n; i++)
cout< cout< cout< cout<<"最短路线长度:"< cout< return 0;
}
/*
测试数据:
5
-1 10 -1 4 12
10 -1 15 8 5
-1 15 -1 7 30
4 8 7 -1 6
12 5 30 6 -1
*/




推荐阅读
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 智能车间调度研究进展
    本文综述了基于强化学习的智能车间调度策略,探讨了车间调度问题在资源有限条件下的优化方法。通过数学规划、智能算法和强化学习等手段,解决了作业车间、流水车间和加工车间中的静态与动态调度挑战。重点讨论了不同场景下的求解方法及其应用前景。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 深入理解Java中的Collection接口与Collections工具类
    本文详细解析了Java中Collection接口和Collections工具类的区别与联系,帮助开发者更好地理解和使用这两个核心组件。 ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 最近团队在部署DLP,作为一个技术人员对于黑盒看不到的地方还是充满了好奇心。多次咨询乙方人员DLP的算法原理是什么,他们都以商业秘密为由避而不谈,不得已只能自己查资料学习,于是有了下面的浅见。身为甲方,虽然不需要开发DLP产品,但是也有必要弄明白DLP基本的原理。俗话说工欲善其事必先利其器,只有在懂这个工具的原理之后才能更加灵活地使用这个工具,即使出现意外情况也能快速排错,越接近底层,越接近真相。根据DLP的实际用途,本文将DLP检测分为2部分,泄露关键字检测和近似重复文档检测。 ... [详细]
  • 堆是一种常见的数据结构,广泛应用于计算机科学领域。它通常表示为一棵完全二叉树,并可通过数组实现。堆的主要特性是每个节点的值与其父节点的值之间存在特定的关系,这使得堆在优先队列和排序算法中非常有用。 ... [详细]
  • 探索电路与系统的起源与发展
    本文回顾了电路与系统的发展历程,从电的早期发现到现代电子器件的应用。文章不仅涵盖了基础理论和关键发明,还探讨了这一学科对计算机、人工智能及物联网等领域的深远影响。 ... [详细]
  • 2018年3月31日,CSDN、火星财经联合中关村区块链产业联盟等机构举办的2018区块链技术及应用峰会(BTA)核心分会场圆满举行。多位业内顶尖专家深入探讨了区块链的核心技术原理及其在实际业务中的应用。 ... [详细]
  • 本题探讨了在大数据结构背景下,如何通过整体二分和CDQ分治等高级算法优化处理复杂的时间序列问题。题目设定包括节点数量、查询次数和权重限制,并详细分析了解决方案中的关键步骤。 ... [详细]
  • 机器学习核心概念与技术
    本文系统梳理了机器学习的关键知识点,涵盖模型评估、正则化、线性模型、支持向量机、决策树及集成学习等内容,并深入探讨了各算法的原理和应用场景。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 随着生活节奏的加快和压力的增加,越来越多的人感到不快乐。本文探讨了现代社会中导致人们幸福感下降的各种因素,并提供了一些改善建议。 ... [详细]
author-avatar
fuzhipai
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有