Dijkstra算法Java实现

本文介绍了如何使用Dijkstra算法解决最短路径问题。通过广度优先搜索和贪心策略,从给定的起点逐步修正到各顶点的最短路径。详细解题步骤包括存储路径信息、标记访问状态、选择最近未访问顶点和修正路径权重。最后展示了算法运行结果,给出了从起点到各顶点的最短路径数组。

题目描述:

给定一个图,给定各个顶点之间的路径长度,求解从图中一个节顶点出发到任意节顶点的最短距离。

解题思路:

我们采用Dijkstra算法求解最短路径,Dijkstra算法采用广度优先搜索和贪心策略实现求解单源最短路径。选择离出发顶点最近的顶点并以这个顶点为中心调整出发顶点到那些周边顶点的最短距离,不断遍历并且修正,直到从出发顶点到任意顶点的权重修正完全。
例题图示:
在这里插入图片描述
详细解题步骤:
1、把各个顶点之间的路径长度信息存入一个二维数组,再确定一个出发点,作为参数并调用获取最短路径的方法。

	public static void main(String[] args)
	{
   
   
		Test test = new Test();
		int MAX=Integer.MAX_VALUE-10000;
		int[][] weight={
   
   
				{
   
   0,1,12,MAX,MAX,MAX},
                {
   
   MAX,0,9,3,MAX,MAX},
                {
   
   MAX,MAX,0,MAX,5,MAX},
                {
   
   4,0
评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值