算法 |【实验5.2】1-深度优先搜索暴力求解旅行商问题

简介: 算法 |【实验5.2】1-深度优先搜索暴力求解旅行商问题

使用深度优先搜索暴力求解旅行商问题


1.题目描述

商品推销员要去n个城市推销商品,城市从1至n编号,任意两个城市间有一定距离,该推销员从城市1出发,需要经过所有城市并回到城市1,求最短总路径长度。


把旅行商问题看作一种排列问题,不难想出,这道题的蛮力做法即穷举所有路线。选定起点有n种选法,选定起点后的下一个目的地有(n- 1)种选择方法,再下一个是(n-2)……总共有n!种排列方法,算法复杂度达到O(n!)。


一个20城市的TSP问题有大约60,000,000,000,000,000个可能解。如果一台计算机每秒搜索1000个解,需要大约1902587年才能搜索完所有的解。


因此蛮力法只能解决小规模问题。


image.png


2.问题分析与算法设计思路


总体思路: 深度优先搜索,递归


算法过程:


使用二维数组 dis 存放任意两个城市之间的距离


从城市 1 开始


使用一个循环遍历下一个城市的不同选择,且忽略已经走过的城市、不能直接到达的城市


每次遍历,更新到达当前城市走过的路径长度 len 。


走过所有城市后,len 再加上当前城市到城市 1 的距离(最后要回到 1 ),保存该条路径的长度。


在所有路径长度中找出最小值。


小结:


“先规划好思路,然后才开始编写代码”,这句话很早就听到说过了,但是能真正静下心来做到这一点的时候,却是不多。但我感觉,这很有用。


3.算法实现


完整可运行代码,C++实现:


//深度优先搜索求解旅行商问题
#include<iostream>
using namespace std;
const int Max = 10;
int len_min = 999;//最短总路径长度
int road[Max] = {1};//存放路径 
int it_r = 1;
//搜索求解
//参数dis:城市距离,now:所在城市,have:走过城市,
//len:走过路径长度,n:城市总数,num:已走过城市数 
void dfs(int dis[][Max], int now, bool have[], int len, int n, int num){
    //显示路径 
    cout<<"road:";
    for(int i = 0; i < it_r; i++){
        cout<<road[i]<<" ";
    }
    cout<<endl;
    //一条完整路径 
    if(num == n){
        len += dis[now][1];
        if(len < len_min){
            len_min = len;
        }
    }
    //遍历下一个城市 
    for(int i = 2; i <= n; i++){
        //排除已走过、不能到达的城市 
        if(have[i] == true || dis[now][i] == 0){
            continue;
        }
        int len_next = len + dis[now][i];
        have[i] = true;
        road[it_r++] = i;
        dfs(dis, i, have, len_next, n, num+1);
        road[--it_r] = 0;
        have[i] = false;
    }
}
int main(){
    int dis[Max][Max] = {};//任意两城市距离,0表示不能直接到达 
    bool have[Max] = {1};//已走过哪些城市 
    int n = 0;//城市的个数
    int e = 0;//道路的个数
    cin>>n>>e;
    for(int i = 1; i <= e; i++){
        int a = 0, b = 0, x = 0;
        cin>>a>>b>>x;
        dis[a][b] = x;
        dis[b][a] = x;
    } 
    //显示城市距离 
    for(int i = 1; i <= n; i++){
        for(int j = 1; j <= n; j++){
            cout<<dis[i][j]<<" ";
        }
        cout<<endl;
    }
    dfs(dis, 1, have, 0, n, 1);
    cout<<"最短路径:"<<len_min;
    return 0;
} 
/*
测试数据一 
4 5
1 2 5
1 3 3
1 4 4
2 3 7
2 4 6
*/

4.运行结果

image.png


5.算法分析

算法的时间复杂度在前面的题目描述中已经讲到了,达到了o ( n ! ) o(n!)o(n!) 。


空间复杂度应为o ( n 2 ) o(n^2)o(n2),因为使用了二维数组来存放城市间距离。

相关文章
|
11月前
|
算法 测试技术 定位技术
数据结构与算法——DFS(深度优先搜索)
数据结构与算法——DFS(深度优先搜索)
|
5月前
|
人工智能 运维 算法
基于 C# 深度优先搜索算法的局域网集中管理软件技术剖析
现代化办公环境中,局域网集中管理软件是保障企业网络高效运行、实现资源合理分配以及强化信息安全管控的核心工具。此类软件需应对复杂的网络拓扑结构、海量的设备信息及多样化的用户操作,而数据结构与算法正是支撑其强大功能的基石。本文将深入剖析深度优先搜索(Depth-First Search,DFS)算法,并结合 C# 语言特性,详细阐述其在局域网集中管理软件中的应用与实现。
110 3
|
6月前
|
监控 算法 安全
基于 PHP 语言深度优先搜索算法的局域网网络监控软件研究
在当下数字化时代,局域网作为企业与机构内部信息交互的核心载体,其稳定性与安全性备受关注。局域网网络监控软件随之兴起,成为保障网络正常运转的关键工具。此类软件的高效运行依托于多种数据结构与算法,本文将聚焦深度优先搜索(DFS)算法,探究其在局域网网络监控软件中的应用,并借助 PHP 语言代码示例予以详细阐释。
100 1
|
7月前
|
运维 监控 JavaScript
内网网管软件中基于 Node.js 的深度优先搜索算法剖析
内网网管软件在企业网络中不可或缺,涵盖设备管理、流量监控和安全防护。本文基于Node.js实现深度优先搜索(DFS)算法,解析其在网络拓扑遍历中的应用。通过DFS,可高效获取内网设备连接关系,助力故障排查与网络规划。代码示例展示了图结构的构建及DFS的具体实现,为内网管理提供技术支持。
103 11
|
7月前
|
机器学习/深度学习 算法
算法系列之搜索算法-深度优先搜索DFS
深度优先搜索和广度优先搜索一样,都是对图进行搜索的算法,目的也都是从起点开始搜索,直到到达顶点。深度优先搜索会沿着一条路径不断的往下搜索,直到不能够在继续为止,然后在折返,开始搜索下一条候补路径。
330 62
算法系列之搜索算法-深度优先搜索DFS
|
6月前
|
算法 安全 Java
算法系列之深度优先搜索寻找妖怪和尚过河问题的所有方式
在算法学习中,深度优先搜索(DFS)是一种常用的图搜索算法,通过递归或栈实现,适合路径搜索、连通性、拓扑排序、回溯、生成、环路检测、强连通分量和可达性等问题。本文将介绍如何利用深度优先搜索解决“妖怪和尚过河问题”的所有方式。
135 26
算法系列之深度优先搜索寻找妖怪和尚过河问题的所有方式
|
6月前
|
监控 算法 JavaScript
企业用网络监控软件中的 Node.js 深度优先搜索算法剖析
在数字化办公盛行的当下,企业对网络监控的需求呈显著增长态势。企业级网络监控软件作为维护网络安全、提高办公效率的关键工具,其重要性不言而喻。此类软件需要高效处理复杂的网络拓扑结构与海量网络数据,而算法与数据结构则构成了其核心支撑。本文将深入剖析深度优先搜索(DFS)算法在企业级网络监控软件中的应用,并通过 Node.js 代码示例进行详细阐释。
97 2
|
6月前
|
存储 算法 JavaScript
基于 Node.js 深度优先搜索算法的上网监管软件研究
在数字化时代,网络环境呈现出高度的复杂性与动态性,上网监管软件在维护网络秩序与安全方面的重要性与日俱增。此类软件依托各类数据结构与算法,实现对网络活动的精准监测与高效管理。本文将深度聚焦于深度优先搜索(DFS)算法,并结合 Node.js 编程语言,深入剖析其在上网监管软件中的应用机制与效能。
84 6
|
7月前
|
存储 人工智能 算法
【深度优先搜索篇】走迷宫的魔法:算法如何破解迷宫的神秘密码
【深度优先搜索篇】走迷宫的魔法:算法如何破解迷宫的神秘密码
|
10月前
|
算法
数据结构之路由表查找算法(深度优先搜索和宽度优先搜索)
在网络通信中,路由表用于指导数据包的传输路径。本文介绍了两种常用的路由表查找算法——深度优先算法(DFS)和宽度优先算法(BFS)。DFS使用栈实现,适合路径问题;BFS使用队列,保证找到最短路径。两者均能有效查找路由信息,但适用场景不同,需根据具体需求选择。文中还提供了这两种算法的核心代码及测试结果,验证了算法的有效性。
356 23

热门文章

最新文章