数据结构-基于邻接表实现图的遍历可视化及使用Floyd、Dijkstra算法求解最短路径(JavaScript实现)

使用 JavaScript 基于邻接表实现了图的深度、广度遍历,以及 Floyd、Dijkstra 算法求解最短路径。

另外使用 SVG 实现图的遍历可视化。

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>图论</title>
	<style type="text/css">
   		.container{
   			width: 600px;
   			height: 800px;
   			margin: 0 auto;
   		}
		.node{
			width: 100px;
			min-height: 100px;
		}
		.circle{
			margin: 0 auto;
			width: 50px;
			height: 50px;
		}
   </style>
</head>
<body>
<div class="container">
	<div class="control">
	选择开始遍历的结点:
		<select id="node">
			<option>v0</option>
		</select>
	选择遍历方式:
		<select id="select">
			<option>深度优先遍历</option>
			<option>广度优先遍历</option>
		</select>
		<input type="button" name="click" value="开始遍历" id="button">
	</div>
	<svg id="svg" width="600" height="600"></svg>
</div>
<script type="text/javascript">
(function(){
//存放图结点的数组
var graphVertex = ["v0","v1","v2","v3","v4","v5","v6"];
//存放图边的数组
var graphAdge = [
	{
		start:"v0",
		end: "v2",
		weight: 2
	},
	{
		start:"v0",
		end: "v5",
		weight: 8
	},
	{
		start:"v3",
		end: "v2",
		weight: 1
	},
	{
		start:"v3",
		end: "v5",
		weight: 3
	},
	{
		start:"v4",
		end: "v1",
		weight: 6
	},
	{
		start:"v5",
		end: "v4",
		weight: 8
	},
	{
		start:"v1",
		end: "v2",
		weight: 8
	},
	{
		start:"v1",
		end: "v6",
		weight: 8
	}
];
//图的构造函数,n:结点数量 , e: 边的数量
var GraphList = function(graphVertex,graphAdge){
	var vertex = [];//存放图中顶点的数组
	var adjList = [];//存放图中边的邻接矩阵
	var n = graphVertex.length, e = graphAdge.length;
	//初始化邻接表
	var initArr = function(){
		//深拷贝,不改变输入数组
		vertex = JSON.parse(JSON.stringify(graphVertex));
		//顶点和边的数量
		var n = graphVertex.length, e = graphAdge.length;
		//初始化arc数组
		for(let i=0;i<n;i++){
			adjList[i] = {
				"vertex": vertex[i],
				"firstEdge": null
			};
		}
		//console.log(adjList);
		//给arc邻接矩阵填充边的权值
		for(let i=0;i<e;i++){
			var start = graphVertex.indexOf(graphAdge[i].start);
			var end = graphVertex.indexOf(graphAdge[i].end);
			if(start===-1||end===-1){
				throw Error("边数组中有结点不在结点数组中");
				return;
			}
			var s = {
				"node": end,
				"weight": graphAdge[i].weight,
				"next": adjList[start].firstEdge
			}
			adjList[start].firstEdge = s;

			//无向图需要下面这两个,有向图不需要
			var t = {
				"node": start,
				"weight": graphAdge[i].weight,
				"next": adjList[end].firstEdge
			}
			adjList[end].firstEdge = t;
		}
		//console.log(adjList);
	};
	//立即执行函数,初始化
	(function(){
		initArr();
	})();

	//图的深度优先遍历
	var dfsTraverse = function(v){
		//输入检测
		if(vertex.indexOf(v)===-1){
			throw Error("广度优先遍历输入结点不在结点数组中");
			return;
		}
		
		var result = [],visited = [];
		var stack = [];
		stack.push(v);
		result.push(v);
		visited[vertex.indexOf(v)] = true;
		while(stack.length!==0){
			let top = stack.pop();
			if(visited[ver
  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值