最短路径:Dijkstra算法 C#
class Program
{
const int u = ; static void Main(string[] args)
{
Console.WriteLine("各点距离矩阵如下:");
Console.WriteLine(" A B C D E");
Console.WriteLine("A 0 2 3 / /");
Console.WriteLine("B 2 0 3 5 2");
Console.WriteLine("C 3 3 0 2 4");
Console.WriteLine("D / 5 2 0 1");
Console.WriteLine("E / 2 4 1 0");
int[,] matrix = new int[, ] { { , , , u, u }, { , , , , }, { , , , , }, { u, , , , }, { u, , , , } };
while (true)
{
Console.WriteLine("请输入要计算的起始点:");
string a = Console.ReadLine();
int start;
switch (a.ToLower())
{
default:
case "a":
start = ;
break;
case "b":
start = ;
break;
case "c":
start = ;
break;
case "d":
start = ;
break;
case "e":
start = ;
break;
}
var list = Dijkstra(matrix, start); for (int i = ; i < list.Count; i++)
{
Console.WriteLine("从" + a.ToUpper() + "出发到" + i.IndexToChar() + "的最短距离为:" + list[i].Distance + ",最短路径为:" + list[i].Path);
}
}
} public static List<ShortPath> Dijkstra(int[,] matrix, int start)
{
int n = matrix.GetLength();
int[] visited = new int[n];
var list = new List<ShortPath>(); for (int i = ; i < n; i++)
{
list.Add(new ShortPath() { Index = i, Name = start.IndexToChar() + "->" + i.IndexToChar(), Path = start.IndexToChar() + "->" + i.IndexToChar(), Distance = });
}
visited[start] = ;
for (int i = ; i < n; i++)
{
int k = -;
int dmin = u;
for (int j = ; j < n; j++)
{
if (visited[j] == && matrix[start, j] < dmin)
{
dmin = matrix[start, j];
k = j;
}
} list[k].Distance = dmin; visited[k] = ;
for (int j = ; j < n; j++)
{
if (visited[j] == && matrix[start, k] + matrix[k, j] < matrix[start, j])
{
matrix[start, j] = matrix[start, k] + matrix[k, j];
list[j].Path = list[k].Path + "->" + j.IndexToChar();
}
}
} return list;
}
} public static class Common
{
/// <summary>
/// 索引转换字母
/// </summary>
/// <param name="index">当前索引</param>
/// <param name="startIndex">起始索引 默认0</param>
/// <returns></returns>
public static char IndexToChar(this int index, int startIndex = )
{
return (char)('A' + index - startIndex);
}
} public class ShortPath
{
private int index;
private string name;
private string path;
private int distance; public string Path { get => path; set => path = value; }
public int Distance { get => distance; set => distance = value; }
public string Name { get => name; set => name = value; }
public int Index { get => index; set => index = value; }
}
最短路径:Dijkstra算法 C#的更多相关文章
- 网络最短路径Dijkstra算法
最近在学习算法,看到有人写过的这样一个算法,我决定摘抄过来作为我的学习笔记: <span style="font-size:18px;">/* * File: shor ...
- 单源最短路径Dijkstra算法,多源最短路径Floyd算法
1.单源最短路径 (1)无权图的单源最短路径 /*无权单源最短路径*/ void UnWeighted(LGraph Graph, Vertex S) { std::queue<Vertex&g ...
- 最短路径-Dijkstra算法与Floyd算法
一.最短路径 ①在非网图中,最短路径是指两顶点之间经历的边数最少的路径. AE:1 ADE:2 ADCE:3 ABCE:3 ②在网图中,最短路径是指两顶点之间经历的边上权值之和最短的路径 ...
- 数据结构实验之图论七:驴友计划 ( 最短路径 Dijkstra 算法 )
数据结构实验之图论七:驴友计划 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Probl ...
- 最短路径——Dijkstra算法以及二叉堆优化(含证明)
一般最短路径算法习惯性的分为两种:单源最短路径算法和全顶点之间最短路径.前者是计算出从一个点出发,到达所有其余可到达顶点的距离.后者是计算出图中所有点之间的路径距离. 单源最短路径 Dijkstra算 ...
- 有向网络(带权的有向图)的最短路径Dijkstra算法
什么是最短路径? 单源最短路径(所谓单源最短路径就是只指定一个顶点,最短路径是指其他顶点和这个顶点之间的路径的权值的最小值) 什么是最短路径问题? 给定一带权图,图中每条边的权值是非负的,代表着两顶点 ...
- Python数据结构与算法之图的最短路径(Dijkstra算法)完整实例
本文实例讲述了Python数据结构与算法之图的最短路径(Dijkstra算法).分享给大家供大家参考,具体如下: # coding:utf-8 # Dijkstra算法--通过边实现松弛 # 指定一个 ...
- 求两点之间最短路径-Dijkstra算法
Dijkstra算法 1.定义概览 Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.D ...
- 最短路径—Dijkstra算法
Dijkstra算法 1.定义概览 Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.Di ...
- 单源最短路径——Dijkstra算法学习
每次都以为自己理解了Dijkstra这个算法,但是过没多久又忘记了,这应该是第4.5次重温这个算法了. 这次是看的胡鹏的<地理信息系统>,看完之后突然意识到用数学公式表示算法流程是如此的好 ...
随机推荐
- 关于VIM中展示二进制字符的操作
在网上拷贝了一段代码放到linux下变异,发现每行的行首有一堆不可识别的字符.放到windows的notepad下发现也不是空格也不是tab,权当是某种不可识别的缩进字符把 解决方法 linux c ...
- maven将本地jar包引入本地maven仓库命令
一.maven安装命令.cmd窗口,idea中均可 mvn install:install-file -Dfile=F:\coding2pay\pay\lib/wxpay-sdk-.jar -Dgro ...
- oracle修改已存在数据的字段类型
第一次使用oracle数据库,在通过Navicat premium工具修改字段类型时,发现报“ORA-01439: column to be modified must be empty to cha ...
- BZOJ 4127: Abs (树链剖分 线段树求区间绝对值之和 带区间加法)
题意 给定一棵树,设计数据结构支持以下操作 1 u v d 表示将路径 (u,v) 加d(d>=0) 2 u v 表示询问路径 (u,v) 上点权绝对值的和 分析 绝对值之和不好处理,那么我们开 ...
- (转载)Google 发布 Android 性能优化典范
2015年伊始,Google发布了关于Android性能优化典范的专题, 一共16个短视频,每个3-5分钟,帮助开发者创建更快更优秀的Android App.课程专题不仅仅介绍了Android系统中 ...
- [Mysql]过大sql文件导入过慢问题解决
控制 MySQL 磁盘写入策略 以及 数据安全性 的两个关键参数: innodb_flush_log_at_trx_commit 和 sync_binlog 参数:innodb_flush_log_a ...
- java+大文件上传
javaweb上传文件 上传文件的jsp中的部分 上传文件同样可以使用form表单向后端发请求,也可以使用 ajax向后端发请求 1.通过form表单向后端发送请求 <form id=" ...
- The Semantics of Constructors(拷贝构造函数之编译背后的行为)
本文是 Inside The C++ Object Model's Chapter 2 的部分读书笔记. 有三种情况,需要拷贝构造函数: 1)object直接为另外一个object的初始值 2)ob ...
- Thread(简单使用)
/***thread.c***/#include<stdio.h> #include<stdlib.h> #include<pthread.h> void prin ...
- canvas风景时钟
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...