C# 数据结构之【图】C#图

1. 图的概念

图是一种重要的数据结构,用于表示节点(顶点)之间的关系。图由一组顶点和连接这些顶点的边组成。图可以是有向的(边有方向)或无向的(边没有方向),可以是加权的(边有权重)也可以是无权的。

  • 顶点(Vertex):图中的基本单位,代表对象。
  • 边(Edge):连接顶点的线,可以是有向边或无向边。
  • 加权图(Weighted Graph):边上有权重(表示成本、距离等)。
  • 无向图(Undirected Graph):边没有方向,表示双向关系。
  • 有向图(Directed Graph):边有方向,表示单向关系。

2. 创建图的节点模型

cs 复制代码
class GraphNode
{
    public int Data { get; set; }
    public List<GraphNode> Neighbors { get; set; }

    public GraphNode(int data)
    {
        Data = data;
        Neighbors = new List<GraphNode>();
    }
}

3. 使用及遍历

cs 复制代码
using System;

namespace DataStructure
{
    class Program
    {
        static async Task Main(string[] args)
        {
            // 创建图的节点
            GraphNode node1 = new GraphNode(1);
            GraphNode node2 = new GraphNode(2);
            GraphNode node3 = new GraphNode(3);

            // 添加节点之间的边(无向图,所以相互添加)
            node1.Neighbors.Add(node2);
            node2.Neighbors.Add(node1);

            node2.Neighbors.Add(node3);
            node3.Neighbors.Add(node2);

            // 广度优先搜索遍历图并输出节点值
            Console.WriteLine("广度优先搜索遍历图:");
            BFS(node1);
        }

        static void BFS(GraphNode startNode)
        {
            Queue<GraphNode> queue = new Queue<GraphNode>();
            HashSet<GraphNode> visited = new HashSet<GraphNode>();

            queue.Enqueue(startNode);
            visited.Add(startNode);

            while (queue.Count > 0)
            {
                GraphNode currentNode = queue.Dequeue();
                Console.Write(currentNode.Data + " ");

                foreach (GraphNode neighbor in currentNode.Neighbors)
                {
                    if (!visited.Contains(neighbor))
                    {
                        queue.Enqueue(neighbor);
                        visited.Add(neighbor);
                    }
                }
            }
        }
    }
}

运行结果

相关推荐
想唱rap1 小时前
C++ list 类的使用
c语言·开发语言·数据结构·c++·笔记·算法·list
仰泳的熊猫3 小时前
LeetCode:773. 滑动谜题
数据结构·c++·算法·leetcode
赵庆明老师3 小时前
C# 结合Redis Cache 访问MySQL数据库
数据库·redis·c#
yi碗汤园4 小时前
【一文了解】八大排序-冒泡排序、选择排序
开发语言·前端·算法·unity·c#·1024程序员节
huangql5204 小时前
JavaScript数据结构实战指南:从业务场景到性能优化
javascript·数据结构·性能优化
hope_wisdom6 小时前
C/C++数据结构之用链表实现栈
c语言·数据结构·c++·链表·
c#上位机6 小时前
wpf之数据类型转换
c#·wpf·mvvm
大肘子咒你6 小时前
数字狂潮来袭
数据结构·c++·1024程序员节
喵叔哟7 小时前
8. 从0到上线:.NET 8 + ML.NET LTR 智能类目匹配实战--规则回退与可解释性:四层策略如何兜底
人工智能·深度学习·.net
宝桥南山7 小时前
.NET - .NET Aspire的Command-Line和GitHub Copilot
microsoft·微软·c#·asp.net·.net·.netcore