最短路径(算法第四版)(C#)

最短路径的性质
  1. 路径是有向的
  2. 不需要所有边都可达
  3. 负权重会使问题变得更复杂
  4. 最短路径不是唯一的

这里讨论的是单点最短路径,即找出从一个起点到所有可达顶点的最短路径构成的最短路径树

有向加权图的数据结构

有向边的结构比无向边简单,有确定的起点和终点
有向边的结构

public class DirectEdge
    {
   
        private int v;  //起点
        private int w;  //终点
        private double weight;

        public DirectEdge(int form, int to, double weight)
        {
   
            this.v = form;
            this.w = to;
            this.weight = weight;
        }
        public int Form => v;
        public int To => w;
        public double Weight => weight;
    }

加权有向图的结构:

//加权有向图
public class EdgeWeightedDigraph
    {
   
        private int v;
        private List<DirectEdge>[] _adj; //邻接表
        private int e;

        public EdgeWeightedDigraph(string path)
        {
   
            string line;
            System.IO.StreamReader sr = new System.IO.StreamReader(path);
            v = Convert.ToInt32(sr.ReadLine());
            e = 0;
            _adj = new List<DirectEdge>[v];
            for (int i = 0; i < v; i++) { _adj[i] = new List<DirectEdge>(); }
            while ((line = sr.ReadLine()) != null)
            {
   
                string[] str = line.Split(' ');
                int a = Convert.ToInt32(str[0]);
                int b = Convert.ToInt32(str[1]);
                float w = (float)Convert.ToDouble(str[2]);
                AddEdge(new DirectEdge(a, b, w));
            }
        }

        public EdgeWeightedDigraph(int v)
        {
   
            _adj = new List<DirectEdge>[v];
            for (int i = 0; i < v; i++)
            {
   
                _adj[i] = new List<DirectEdge>();
            }
            this.v = v;
            e = 
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值