热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

重新整理数据结构与算法(c#)——算法套路迪杰斯特拉算法[三十一]

前言迪杰斯特拉算法是求最短路径方法的其中一种,这个有什么作用呢?有一张图:假设求G点到其他各点的最小路径。是这样来的。比如找到了和G点相连接所有点,ABED。这时候确定GA是一定是

前言

迪杰斯特拉算法 是求最短路径方法的其中一种,这个有什么作用呢?

有一张图:

重新整理数据结构与算法(c#)——算法套路迪杰斯特拉算法[三十一]

假设求G点到其他各点的最小路径。

是这样来的。

比如找到了和G点相连接所有点,ABED。这时候确定GA是一定是最短的,为什么这么说呢?G->A和G从别的点到A,一旦G走BED 一定会大于GA,后续就跟不可能大于了。

所以GA为最短,这时候就确定了A。这时候开始从A点开始,找到和A点相连但是没有确定最短的点,有B、C。G->A->B 大于G->B。然后A可以到C,这时候确定G->C 是9。

然后从G到各点已经相连中,找到没有确认的最小路径,这个就是确认了G->B最短。为什么能够确认呢?因为G到A然后到B大于G->B,那么可以确认G到B最短,这是因为GA是最短的,从最短的到不了,其他的一定大于G->B。

上面说其实有点模糊。

是这样的,如果从G为出发点确认了n个点,那么剩下的m个点怎么确认呢?

肯定就是从G从到先到G最短的点,尝试是否有其他路,如果没有,那么就确认了。

正文

代码如下:

class Program
{
	private static int INF = int.MaxValue;

	static void Main(string[] args)
	{
		char[] vertex = { 'A', 'B', 'C', 'D', 'E', 'F', 'G' };
		int N = 65535;// 表示不可以连接
		int[,] matrix = { { N, 5, 7, N, N, N, 2 },
		{ 5, N, N, 9, N, N, 3 },
		{ 7, N, N, N, 8, N, N },
		{ N, 9, N, N, N, 4, N },
		{ N, N, 8, N, N, 5, 4 },
		{ N, N, N, 4, 5, N, 6 },
		{ 2, 3, N, N, 4, 6, N }
		};
		//创建 Graph对象
		Graph graph = new Graph(vertex, matrix);
		//测试, 看看图的邻接矩阵是否ok
		graph.showGraph();
		//测试迪杰斯特拉算法
		graph.dsj(2);//C
		graph.showDijkstra();
		Console.Read();
	}
}
class Graph
{
	private char[] vertex;//顶点数组
	private int[,] matrix;//邻接矩阵
	private VisitedVertex vv;//顶点状态
	public Graph(char[] vertex, int[,] matrix)
	{
		this.vertex = vertex;
		this.matrix = matrix;
	}

	public void showDijkstra()
	{
		vv.show();
	}

	public void showGraph()
	{
		for (int i = 0; i 
	/// 是否访问过
	/// 
	/// 下标距离
	/// 
	public Boolean isVisited(int index)
	{
		return already_arr[index] == 1;
	}
	//更新距离
	public void updateDis(int index, int length)
	{
		dis[index] = length;
	}

	//更新前驱节点
	public void updatePre(int index, int pre)
	{
		pre_visited[index] = pre;
	}
	//返回到某个节点的距离
	public int getDis(int index)
	{
		return dis[index];
	}
	//显示最后的结果
	//即将三个数组的情况输出
	public void show()
	{
		Console.WriteLine("输出前驱");
		//输出pre_visited
		foreach (int i in pre_visited)
		{
			Console.Write(i + " ");
		}
		Console.WriteLine();
		char[] vertex = { 'A', 'B', 'C', 'D', 'E', 'F', 'G' };
		int count = 0;
		foreach (int i in dis)
		{
			if (i != 65535)
			{
				Console.Write(vertex[count] + "(" + i + ") ");
			}
			else
			{
				Console.Write("N ");
			}
			count++;
		}
		Console.WriteLine();
	}
}

结果:

重新整理数据结构与算法(c#)——算法套路迪杰斯特拉算法[三十一]


推荐阅读
  • 本文讨论了编写可保护的代码的重要性,包括提高代码的可读性、可调试性和直观性。同时介绍了优化代码的方法,如代码格式化、解释函数和提炼函数等。还提到了一些常见的坏代码味道,如不规范的命名、重复代码、过长的函数和参数列表等。最后,介绍了如何处理数据泥团和进行函数重构,以提高代码质量和可维护性。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 2020年第十一届蓝桥杯决赛JAVA B G题“皮亚诺曲线距离“的个人题解目录
    本文是2020年第十一届蓝桥杯决赛JAVA B G题“皮亚诺曲线距离“的个人题解目录。文章介绍了皮亚诺曲线的概念和特点,并提供了计算皮亚诺曲线上两点距离的方法。通过给定的两个点的坐标,可以计算出它们之间沿着皮亚诺曲线走的最短距离。本文还提供了个人题解的目录,供读者参考。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • 本文介绍了一种在PHP中对二维数组根据某个字段进行排序的方法,以年龄字段为例,按照倒序的方式进行排序,并给出了具体的代码实现。 ... [详细]
  • Todayatworksomeonetriedtoconvincemethat:今天在工作中有人试图说服我:{$obj->getTableInfo()}isfine ... [详细]
author-avatar
NethJ
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有