最短路径: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次重温这个算法了. 这次是看的胡鹏的<地理信息系统>,看完之后突然意识到用数学公式表示算法流程是如此的好 ...
随机推荐
- 小程序UI设计(10)-巧用模板,事半功倍
工具中为小程序员们准备了符合微信开发规范的模板.之前帖子中介绍的规范都在模板中已经设计好了,可以直接复制粘贴使用.下图中的样式是从模板直接复制过来的.实际使用时只要更换为自己的图片和文字即可.自动生成 ...
- struts2使用注解的时候遇到的问题
问题描述: 一切配置和注解都正确,但是无法访问action中的方法 解决问题: 之前将action层的包名命名成了web,改成action就对了 原因: struts2 ...
- 关于注解-Hebernate与JPA(java persistence api)
The JPA spec. defines the JPA annotation in the javax.persistence package. Hibernate not only implem ...
- 第六章 组件 60 组件切换-应用切换动画和mode方式
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- 网卡绑定(bonding)
就是将多块网卡绑定同一IP地址对外提供服务,可以实现高 可用或者负载均衡.当然,直接给两块网卡设置同一IP地址 是不可能的.通过bonding,虚拟一块网卡对外提供连接, 物理网卡的被修改为相同的MA ...
- grub命令行和配置文件配置配置信息
一.grub简介 GNU GRUB(简称“GRUB”)是一个来自GNU项目的启动引导程序.GRUB是多启动规范的实现,它允许用户可以在计算机内同时拥有多个操作系统,并在计算机启动时选择希望运行的操作系 ...
- openssl数据加密
一.openssl简介 openssl是最著名的开源SSL,其用 C 实现,被广泛应用在基于TCP/Socket的网络程序中. OpenSSL:开源项目 三个组件:openssl: 多用途的命令行工具 ...
- .NET Core 3时代DevExpress Winforms v19.2增强Scheduler控件
DevExpress Winforms Controls 内置140多个UI控件和库,完美构建流畅.美观且易于使用的应用程序.无论是Office风格的界面,还是分析处理大批量的业务数据,DevExpr ...
- k8sSecret资源
Secret资源的功能类似于ConfigMap,但它专用于存放敏感数据,如密码.数字证书.私钥.令牌和ssh key等. 一.概述 Secret对象存储数据以键值方式存储数据,再pod资源中通过环境变 ...
- router-link to 动态赋值
路由定义: 动态赋值: <router-link :to="{path:'/old_data_details/params/'+item.id}" > </rou ...