最短路径: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次重温这个算法了. 这次是看的胡鹏的<地理信息系统>,看完之后突然意识到用数学公式表示算法流程是如此的好 ...
随机推荐
- sql 178. 分数排名
编写一个 SQL 查询来实现分数排名.如果两个分数相同,则两个分数排名(Rank)相同.请注意,平分后的下一个名次应该是下一个连续的整数值.换句话说,名次之间不应该有“间隔”. +----+----- ...
- Java 实现的 简单WordCount功能
githup 链接:https://gitee.com/iy2524/WordCount.git PSP表格 psp2.1 psp阶段 估计耗时(分钟) 实际耗时(分钟) Planning 计 ...
- Java-FileUploadUtil工具类
package com.gootrip.util; import java.io.File; import java.util.*; import org.apache.commons.fileupl ...
- C++中虚函数继承类的内存占用大小计算
计算一个类对象的大小时的规律: 1.空类.单一继承的空类.多重继承的空类所占空间大小为:1(字节,下同): 2.一个类中,虚函数本身.成员函数(包括静态与非静态)和静态数据成员都是不占用类对象的存储空 ...
- django之表多对多建立方式、form组件、钩子函数 08
目录 多对多三种创建方式 1.全自动(用ManyToManyField创建第三张表) 2.纯手写 3.半自动 form组件 引入 form组件的使用 forms组件渲染标签 form表单展示信息 fo ...
- 【转】java中的clone
java中的clone Clone&Copy 假设现在有一个Employee对象,Employee tobby =new Employee("CMTobby",5000), ...
- 【C#-批量插入数据到数据库】DataTable数据批量插入数据的库三种方法:SqlCommand.EcecuteNonQurery(),SqlDataAdapter.Update(DataTable) ,SqlBulkCopy.WriteToServer(Datatable)
第一种方法:使用SqlCommand.EcecuteNonQurery() 效率最慢 第二种方法:使用SqlDataAdapter.Update(DataTable) 效率次之 第三种方法:使用 ...
- javaScript高级程序设计第3版笔记
<script src = "xxx.js" defer = "defer"> </script> 在引用外部script时,<s ...
- ETL工具-KETTLE教程专栏1----术语和定义
1-资源库 资源库是用来保存转换任务的,用户通过图形界面创建的的转换任务可以保存在资源库中. 资源库可以使多用户共享转换任务,转换任务在资源库中是以文件夹形式分组管理的,用户可以自定义文 ...
- Codeforces 474D Flowers(DP)
题目链接 非常简单的一道dp题,通过O(n)的预处理来使查询变为O(1). 主要的坑在于取模后的dp数组的前缀和再相减可能得到负数,导致无法得到某一区间和的取模. 解决方法:(a-b)%mo==(a% ...