最小生成树(C#)(算法第四版)

本文介绍了最小生成树的概念,针对加权无向图,讲解了Prim算法的延时和即时两种实现方式,以及Kruskal算法的详细过程。讨论了算法的空间和时间复杂度,并提供了C#代码实现。
摘要由CSDN通过智能技术生成

最小生成树 - 加权无向图(算法第四版)

约定

这里只简单的介绍一般情况下的最小生成树问题,因此最加权图数据做了一些规定:

  1. 只考虑连通图(如果不满足会产生最小森林)
  2. 所有边的权重不同(不满足会出现多个最小生成树)

加权图数据结构

using System;
using System.Collections.Generic;
using System.Text;

namespace{
   
    public class EdgeWeightedGraph
    {
   
        private List<Edge>[] _adj; //邻接表
        private int _v; //结点数
        private int _e; //边数

        /// <summary>
        /// 按文件数据生成一个加权无向图,
        /// </summary>
        /// <param name="path">图文件路径</param>
        public EdgeWeightedGraph(string path)
        {
   
            string line;
            System.IO.StreamReader sr = new System.IO.StreamReader(path);
            _v = Convert.ToInt32(sr.ReadLine());
            _e = 0;
            _adj = new List<Edge>[_v];
            for (int i = 0; i < _v; i++) { _adj[i] = new List<Edge>(); }
            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 Edge(a,b,w));
            }
        }

        public int V => _v;
        public int E => _e;

        public EdgeWeightedGraph(int v)
        {
   
            this._v = v;
            _adj = new List<Edge>[v];
        }

        public void AddEdge(Edge e)
        {
   
            int v = e.Either
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值