JS实现深度优先搜索求解两点间最短路径

 更新时间:2019年01月17日 11:19:35   作者:我要潇潇洒洒  
这篇文章主要为大家详细介绍了JS实现深度优先搜索求解两点间最短路径,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了JS实现深度优先搜索求解两点间最短路径的具体代码,供大家参考,具体内容如下

效果:

找出图里点到点最短路径,并打印轨迹

图片如下所示:


代码:

const map = [
  [0, 1, 1, 0, 1],
  [1, 0, 0, 1, 0],
  [1, 0, 0, 0, 1],
  [0, 1, 0, 0, 0],
  [1, 0, 1, 0, 0]
]

function dfsManager(map, start, end){

  var min = 9999,
    path = [],
    unvisited = [];
  for(let i=0; i<5;i++){
    unvisited[i] = true
  }

  (function dfs(map, start, end, step){
    //unvisited[start] = false //不重复访问最后的节点
    if(start === end){
      console.log('step:',step)
      for(let i=0; i<path.length; i++){
        if(path[i] >= 0){
          console.log(path[i]+'->')
        }
      }
      if(min > step){
        min = step
      }
      return
    }
    unvisited[start] = false  //要重复访问最后的节点
    let len = map.length

    for(let i=0; i<len; i++){
      if(map[start][i] === 1 && unvisited[i]){
        path.push(i)  //记录路径
        dfs(map, i, end, step+1)
        path.pop()   //避免污染其他路径
      }
    }
  })(map, start, end, 0)

  return min
}

console.log('min:',dfsManager(map,3,4))

output:

step: 4
1->
0->
2->
4->
step: 3
1->
0->
4->
min: 3

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

相关文章

  • javascript中的闭包概念与用法实践分析

    javascript中的闭包概念与用法实践分析

    这篇文章主要介绍了javascript中的闭包概念与用法,结合具体实例形式分析了javascript闭包的概念、原理、使用方法及相关操作注意事项,需要的朋友可以参考下
    2019-07-07
  • 浅析js设置控件的readonly与enabled属性问题

    浅析js设置控件的readonly与enabled属性问题

    本篇文章是对js设置控件的readonly与enabled属性问题进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-12-12
  • JS仿QQ好友列表展开、收缩功能(第二篇)

    JS仿QQ好友列表展开、收缩功能(第二篇)

    这篇文章主要介绍了JS仿QQ好友列表展开、收缩功能,当点击一个li元素,其他li元素上的类名清除掉。代码简单易懂,需要的朋友可以参考下
    2017-07-07
  • 微信小程序之页面拦截器的示例代码

    微信小程序之页面拦截器的示例代码

    本篇文章主要介绍了微信小程序之页面拦截器的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • 微信小程序实现watch监听

    微信小程序实现watch监听

    这篇文章主要介绍了微信小程序实现watch监听,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • JS获取本地文件并进行网络传输的代码详解

    JS获取本地文件并进行网络传输的代码详解

    在web中如想要获取用户计算机上的文件我们通常会用到的方法是通过一个表单元素<input type="file">操作用户选择的文件,本文小编给大家介绍了JS获取本地文件并进行网络传输的方法,需要的朋友可以参考下
    2024-08-08
  • JavaScript 阻止超链接跳转的操作方法(多种写法)

    JavaScript 阻止超链接跳转的操作方法(多种写法)

    很多朋友问小编能否通过JavaScript来阻止超链接的跳转呢,今天给大家通过多种写法来实现这一功能,具体实例代码跟随小编一起看看吧
    2021-06-06
  • Javascript毫秒数用法实例

    Javascript毫秒数用法实例

    这篇文章主要介绍了Javascript毫秒数用法,实例分析了javascript获取毫秒数及设置指定时间毫秒数的方法,需要的朋友可以参考下
    2015-02-02
  • 表格头固定而列可滚动的效果

    表格头固定而列可滚动的效果

    表格头固定而列可滚动的效果...
    2007-11-11
  • JavaScript 拖放效果代码

    JavaScript 拖放效果代码

    拖放效果,也叫拖拽、拖动,学名Drag-and-drop ,是最常见的js特效之一。 如果忽略很多细节,实现起来很简单,但往往细节才是难点所在。
    2008-12-12

最新评论