栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

js图数据结构处理 迪杰斯特拉算法代码实例

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

js图数据结构处理 迪杰斯特拉算法代码实例

这篇文章主要介绍了js图数据结构处理 迪杰斯特拉算法代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下


     
     
     
    function Dijkstra(){
//初始化构造一个集合,mapt[i][j]为点i到j的距离,不通的为无穷大
      var mapt = [
 [undefined,undefined,undefined,undefined,undefined,undefined],
 [undefined,Infinity,2,5,Infinity,Infinity],
 [undefined,Infinity,Infinity,2,6,Infinity],
 [undefined,Infinity,Infinity,Infinity,7,1],
 [undefined,Infinity,Infinity,2,Infinity,4],
 [undefined,Infinity,Infinity,Infinity,Infinity,Infinity],
      ];

      var n = mapt.length - 1;
      //开始计算
      this.dijkstra = function(u){ //u为源点
 var dist = []; //dist[i]为点i到y的最短距离
 var p = [];  //p[i] 为点i的前溯点
 var flag = []; //flag[i] 是否已经加入 s集合

 //初始化数据 dist,p,flag
 for(var i = 1; i <= n; i++){
   dist[i] = mapt[u][i]; //从源点到i的距离 
   if(dist[i] == Infinity){ //前溯点如果不通过为-1
     p[i] = -1;
   }else{
     p[i] = u;
   }
    
   flag[i] = false; //都没有选中
 }
  
 flag[u] = true; //选择了源点,s集合只有 u
 
 for(var i = 1; i <= n; i++){
   var t = u; var temp = Infinity;  
   for(var j = 1; j <= n ; j++){ //获取dist里面,v-s集合的最短距离
     if(!flag[j] && dist[j] <= temp){
temp = dist[j];
t = j;
     }
   }
    
   //查看是否找到最短的距离
   if(t == u){
     return {
dist:dist,
p:p
     }; 
   }
    
   //找到了,将t加入集合 s
   flag[t] = true;
    
   for(var k = 1 ; k <= n; k++){ //以t为捷径点(t为前溯点),寻找所有满足条件的点
     if(!flag[k] && mapt[t][k] < Infinity ){
if(dist[k] > (dist[t] + mapt[t][k])){
  dist[k] = dist[t] + mapt[t][k]; //源点到k的距离 > 源点到t的距离 + t到k的距离
  p[k] = t;
}
     }
   }
 }
  
 return {
   dist:dist,
   p:p
 }
 
      }

      this.getpath = function(u){
 var process = this.dijkstra(u);
 var dist = process.dist;
 var p = process.p;
 for(var i = 1; i <= n; i++){
   var start = i;
   var str = i;
   while(start != -1){
     start = p[start]; //迭代出路径
     if(start != -1){
str = str + '、' + start;
     }
   }
   console.log(str);
 }
      }

    }     
    var Dijk = new Dijkstra();
    //console.log(Dijk.dijkstra(1));
    console.log(Dijk.getpath(1));

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/73737.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号