迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 >

C# 中的树形数据结构

作者:迹忆客 最近更新:2024/01/16 浏览次数:

C# 中的树将是本文讨论的主题。数据结构是我们需要知道的第一件事。

你可以使用数据结构更有效地在计算机上排列和存储数据。栈、链表和队列都是顺序数据结构的例子。


C# 中的树形数据结构

一种以树的形式组织起来的层次数据称为树数据结构。它包括一个中心节点、结构节点和通过边连接在一起的子节点。

也可以声明树数据结构的根、分支和叶子是链接的。

可以使用树来表示层次结构中的数据。构成树的每个节点都包含两个子部分:数据和引用。

树最顶端的节点称为根。它下面的两个产品称为左子树和右子树。

编写树节点的代码可能如下所示:

struct node {
  int Data;
  struct node
  *Leftchild;
  struct node
  *Rightchild;
};

C# 中树形数据结构中的基本术语

以下是你在 C# 中的树数据结构中需要了解的基本术语:

  • 根节点:树顶部的节点称为根。每棵树都有一个根,并且一条路由从根通向任何其他节点。
  • 等级节点:节点的级别反映了已生成的节点数量。节点以 1、2 等的级别增量下降,根节点始终位于顶部。
  • 子树节点:节点的后代由子树表示。
  • 父节点:如果根以外的任何节点连接到父节点,则称为父节点。
  • 子节点:当一个节点的边缘下降时,它被称为它的子节点。

C# 中树形数据结构的优点

以下是在 C# 中使用树数据结构的两个优点:

  1. 在将树与其他数据结构(如数组或链表)进行比较时,无需说明树的大小。因此,树在其存储空间方面是有效的。
  2. 相比之下,使用树消除了对链表所需的插入、删除和查找节点等劳动密集型操作的需要。

C# 中构建树形数据结构的步骤

我们这里有一个 C# 中树数据结构的示例。阅读以下步骤以继续操作。

  1. 首先,我们必须有以下库:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
  2. Shanii 类中创建一个名为 node 的类,该类存储 int 类型变量 keyleftn 作为左节点,rightn 作为右节点。

    class node {
      public int key;
      public node leftn, rightn;
    };
    
  3. 然后,从一个节点的对象创建一个根节点和一个名为 z 的节点列表。

    static node rootnode = null;
    static List<node> z = new List<node>();
    
  1. 要使用数据生成节点,我们需要编写一个名为 newnode 的函数来执行此操作。最初,这个新节点的两个子节点都是 null

    static node newnode(int val) {
      node y = new node();
      y.key = val;
      y.leftn = null;
      y.rightn = null;
      return y;
    }
    
  2. 现在,我们将通过使用 if 检查查看节点是否可访问。如果是,那么将使用当前节点的左侧子节点。

    if (rootnode == null) {
      rootnode = node;
    }
    
  3. 如果可用,则使用当前节点子节点。由于该节点的左孩子已经被使用,所以使用右侧子节点。

    else if (z[0].leftn == null) {
      z[0].leftn = node;
    }
    
  4. 将树中新添加节点的地址添加到队列中。因此,它可用于存储有关其子节点的信息。

    else {
      z[0].rightn = node;
      z.RemoveAt(0);
    }
    z.Add(node);
    
  5. 下面的类将用于构造一棵树。

    static void Constructtree(int[] ar, int a) {
      for (int i = 0; i < a; i++) InsrtVal(ar[i]);
    }
    
  6. 下面的函数会根据节点的等级组织节点。

    static void OrderData(node root) {}
    
  7. 最后,我们将调用创建和组织树及其参数所需的函数。

    static void Main() {
      int[] array = { 29, 39, 49, 59, 69, 79 };
      int n = array.Length;
      Constructtree(array, n);
      OrderData(rootnode);
      Console.ReadKey();
    }
    

完整的源代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace tree_example {
  class Shanii {
    class node {
      public int key;
      public node leftn, rightn;
    };
    static node rootnode = null;
    static List<node> z = new List<node>();

    static node newnode(int val) {
      node y = new node();
      y.key = val;
      y.leftn = null;
      y.rightn = null;
      return y;
    }

    static void InsrtVal(int newval) {
      node node = newnode(newval);
      if (rootnode == null) {
        rootnode = node;
      }

      else if (z[0].leftn == null) {
        z[0].leftn = node;
      }

      else {
        z[0].rightn = node;
        z.RemoveAt(0);
      }
      z.Add(node);
    }

    static void Constructtree(int[] ar, int a) {
      for (int i = 0; i < a; i++) InsrtVal(ar[i]);
    }

    static void OrderData(node root) {
      if (root == null)
        return;
      List<node> n = new List<node>();
      n.Add(root);
      while (n.Count > 0) {
        Console.Write(n[0].key + " ");
        if (n[0].leftn != null)
          n.Add(n[0].leftn);
        if (n[0].rightn != null)
          n.Add(n[0].rightn);
        n.RemoveAt(0);
      }
    }

    static void Main() {
      int[] array = { 29, 39, 49, 59, 69, 79 };
      int n = array.Length;
      Constructtree(array, n);
      OrderData(rootnode);
      Console.ReadKey();
    }
  }
}

输出:

29 39 49 59 69 79 

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

C# 中的异常列表

发布时间:2024/01/20 浏览次数:128 分类:编程语言

我们将查看本文中可能引发的 C# 异常。System Exception 类是 C# 编程语言中预定义的异常类,可用于编程。选择代码中可能出现的异常并将其插入到适当的 catch 块中。

C# 中的 lock 语句

发布时间:2024/01/20 浏览次数:166 分类:编程语言

C# 中 lock 语句指定的代码部分不能被多个线程同时访问。C# 中的 lock 语句 lock(obj) 语句规定,在 C# 中,下面这段代码不能被多个线程同时访问。

等待线程在 C# 中完成

发布时间:2024/01/20 浏览次数:70 分类:编程语言

等待 C# 中的线程完成的主要方法有两种:Task.WaitAll()和 Thread.Join()函数。用 C# 中的 Task.WaitAll() 方法等待线程完成 C# 中的 [Task.WaitAll() 方法)用于等待 Task 类的所有对象的完成。

C# 中的线程与任务

发布时间:2024/01/20 浏览次数:127 分类:编程语言

Thread 类创建一个实际的 OS 线程,而 Task 类创建一个在线程池中异步执行的任务。Thread 类在 C# 中创建实际的操作系统级别的线程。用 Thread 类创建的线程会占用堆栈内存等资源,上下文的 CPU 开

在 C# 中停止线程

发布时间:2024/01/20 浏览次数:138 分类:编程语言

在本文中,我将解释如何在 C# 中启动和停止线程。有时,在 C# 中使用线程时,你可能会遇到需要终止线程的情况。C# 确实为你提供了成功执行此操作的方法,本文旨在解释在 C# 中终止线程的过

C# 中的 Thread.Sleep()

发布时间:2024/01/20 浏览次数:128 分类:编程语言

在本指南中,我们将了解为什么在 C# 中使用 thread.sleep() 被认为是有害的。在本指南中,我们将了解为什么在 C# 中使用 thread.sleep() 被认为是有害的,以及为什么不应该使用这种特殊方法。

C# 中的 extern 关键字

发布时间:2024/01/20 浏览次数:125 分类:编程语言

在今天的文章中,我们将学习 C# 中 extern 关键字的功能。在今天的文章中,我们将学习 C# 中 extern 关键字的功能。

C# 将 Int 转换为 Char

发布时间:2024/01/20 浏览次数:137 分类:编程语言

本教程教授如何在 C# 中将 int 转换为 char。在 C# 中使用显式类型转换 Char 将 Int 转换为 Char

在 C# 中创建泛型函数

发布时间:2024/01/20 浏览次数:186 分类:编程语言

我们可以使用类型 T 在 C# 中声明一个泛型数据类型。它既可以用作函数返回类型,也可以用作函数参数的数据类型。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便