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);
                    }
                }
            }
        }
    }
}

运行结果

相关推荐
hccee26 分钟前
DevExpress控件 基本使用
c#
归-途1 小时前
C#构建一个简单的循环神经网络,模拟对话
神经网络·机器学习·c#
怀旧6661 小时前
Java List 集合
java·数据结构·后端·list·个人开发
归-途2 小时前
C#构建一个简单的前馈神经网络
神经网络·机器学习·c#
pursuit_csdn2 小时前
LeetCode 1072. Flip Columns For Maximum Number of Equal Rows
数据结构·算法·leetcode·力扣
冉佳驹2 小时前
数据结构 ——— 直接选择排序算法的实现
c语言·数据结构·算法·排序算法·直接选择排序算法
不修×蝙蝠2 小时前
数据结构--数组实现栈和队列
java·数据结构·数组··队列
老朱佩琪!4 小时前
UNity将脚本中的文本提示显示在编辑器中
unity·c#·编辑器
豚豚糯5 小时前
栈和队列——考研笔记
数据结构·笔记·考研