最重要的非线性数据结构是什么

首页 / 常见问题 / 低代码开发 / 最重要的非线性数据结构是什么
作者:低代码开发工具 发布时间:10-25 13:58 浏览量:5340
logo
织信企业级低代码开发平台
提供表单、流程、仪表盘、API等功能,非IT用户可通过设计表单来收集数据,设计流程来进行业务协作,使用仪表盘来进行数据分析与展示,IT用户可通过API集成第三方系统平台数据。
免费试用

最重要的非线性数据结构是:树。树(Tree)可以用于表示层次关系或者具有树状结构的数据。树结构有很多种常见的变体,比如二叉树、AVL树、红黑树等等,它们都有其独特的优势和应用场景。

一、最重要的非线性数据结构是什么

最重要的非线性数据结构应该是树(Tree),因为它可以用于表示层次关系或者具有树状结构的数据。树结构有很多种常见的变体,比如二叉树、AVL树、红黑树等等,它们都有其独特的优势和应用场景。在计算机科学中,树结构被广泛应用于算法设计、数据库索引、编译器、操作系统等领域。

二、树(Tree)

1、概念

树(Tree)是n(n>=0)个结点的有限集。n=0时称为空树。

在任意一颗非空树中:

  • 有且仅有一个特定的称为根(Root)的结点。
  • 当n>1时,其余结点可分为m(m>0)个互不相交的有限集T1、T2、…..、Tm,其中每一个集合本身又是一棵树,并且称为根的子树(SubTree)。

树的结点:树的结点包含一个数据元素及若干指向其子树的分支。结点拥有的子树数称为结点的度(Degree)。树的度是树内各结点度的最大值。

结点的层次从根开始定义起,根为名列前茅层,根的孩子为第二层,以此类推。树的深度(Depth)或高度是树中结点的最大层次。

2、二叉树

二叉树(Binary Tree)是n(n>=0)个结点的有限集合,该集合或者为空集(空二叉树),或者由一个根结点和两棵互不相交的、分别称为根结点的左子树和右子树的二叉树组成(子树也为二叉树)。

特点:

  • 每个结点非常多有两棵子树,所以二叉树中不存在度大于2的结点。
  • 左子树和右子树是有顺序的,次序不能任意颠倒。
  • 即使树中某结点只有一棵子树,也要区分它是左子树还是右子树。

五种基本形态:

  • 空二叉树
  • 只有一个根结点
  • 根结点只有左子树
  • 根结点只有右子树
  • 根结点既有左子树又有右子树

性质:

  • 在二叉树的第i层上至多有2i-1个结点(i>=1)
  • 深度为k的二叉树至多有2k-1个结点(k>=1)
  • 对任何一棵二叉树T,如果其终端结点数为n0,度为2的结点数为n2,则n0 = n2+1
  • 具有n个结点的完全二叉树的深度为[log2n ] + 1([X]表示不大于X的最大整数)

存储结构:

  • 顺序存储:根据完全二叉树的特性,可以计算出任意节点n的双亲节点及左右孩子节点的序号,因此完全二叉树的节点可以按照从上到下从左到右的顺序依次存储到一维数组中。非完全二叉树存储时应先将其改造为完全二叉树,以空替代不存在的节点,比较浪费存储空间。
  • 链式存储:树结构链式存储类似线性结构链式存储,先定义包含数据域和引用域的节点(Node),然后通过引用域存储节点之间的关系。根据二叉树的结构来看,节点Node至少包含数据域(Data),引用域(左孩子LChild、右孩子RChild),为了方便通过孩子节点查找父节点,引用域中可以考虑添加父节点引用(Parent)。

3、树与二叉树的转换

树转二叉树:

  • 加线:所有兄弟结点之间加一条连线。
  • 抹线:对树中的每个结点,只保留他与名列前茅个孩子结点之间的连线,删除它与其它孩子结点之间的连线。
  • 整理:整理前两步得到的树,使之结构层次分明。

二叉树转树:

  • 加线:若某结点的左孩子结点存在,将左孩子结点的右孩子结点、右孩子结点的右孩子结点……都作为该结点的孩子结点,将该结点与这些右孩子结点用线连接起来。
  • 抹线:删除原二叉树中所有结点与其右孩子结点的连线。
  • 整理:整理前两步得到的树,使之结构层次分明。

4、树的遍历

/// <summary>
/// 先序遍历(DLR)
/// </summary>
/// <![CDATA[首先访问跟节点,然后遍历左子树,最后右子树]]>
static void PreOrder(Node<char> root)
{
    if (root == null)
    {
        return;
    }

    Print(root);
    PreOrder(root.LChild);
    PreOrder(root.RChild);
}

/// <summary>
/// 中序遍历(LDR)
/// </summary>
/// <![CDATA[先遍历左子树,然后根节点,最后遍历右子树]]>
static void InOrder(Node<char> root)
{
    if (root == null)
    {
        return;
    }

    InOrder(root.LChild);
    Print(root);
    InOrder(root.RChild);
}

/// <summary>
/// 后序遍历(LRD)
/// </summary>
/// <![CDATA[先遍历左子树,然后遍历右子树,最后遍历根节点]]>
static void PostOrder(Node<char> root)
{
    if (root == null)
    {
        return;
    }

    PostOrder(root.LChild);
    PostOrder(root.RChild);
    Print(root);
}

/// <summary>
/// 层序遍历
/// </summary>
/// <![CDATA[从上向下从左到右]]>
static void LevelOrder(Node<char> root)
{
    if (root == null)
    {
        return;
    }
    CSeqQueue<Node<char>> sq = new CSeqQueue<Node<char>>(50);
    sq.In(root);
    while (!sq.IsEmpty())
    {
        Node<char> tmp = sq.Out();
        Print(tmp);

        if (tmp.LChild != null)
        {
            sq.In(tmp.LChild);
        }

        if (tmp.RChild != null)
        {
            sq.In(tmp.RChild);
        }
    }
}

延伸阅读1:非线性数据结构有哪些

  • 树(Tree):树是一种非线性的数据结构,它包含一个根节点和若干个子节点,每个节点可能同时又是父节点和子节点。
  • 图(Graph):图是由若干节点和边组成的数据结构,节点之间的连接通过边来表示,节点之间的关系可以是单向的,也可以是双向的。
  • 散列表(Hash table):散列表是根据关键字直接进行访问的数据结构,通过计算一个关键字对应的散列值,可以在O(1)时间内获取关键字对应的值。
最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。

最近更新

什么是外向潜在客户开发
10-30 10:47
产品开发过程的阶段有哪些
10-30 10:47
开发编程团队介绍怎么写
10-30 10:47
开发团队如何组建
10-30 10:47
众筹筑屋开发费用怎么计算
10-30 10:47
产品开发费用怎么记账
10-30 10:47
开发团队如何协调资源
10-30 10:47
汽车系统开发能力包括哪些
10-30 10:47
团队软件开发为什么用git
10-30 10:47

立即开启你的数字化管理

用心为每一位用户提供专业的数字化解决方案及业务咨询

  • 深圳市基石协作科技有限公司
  • 地址:深圳市南山区科技中一路大族激光科技中心909室
  • 座机:400-185-5850
  • 手机:137-1379-6908
  • 邮箱:sales@cornerstone365.cn
  • 微信公众号二维码

© copyright 2019-2024. 织信INFORMAT 深圳市基石协作科技有限公司 版权所有 | 粤ICP备15078182号

前往Gitee仓库
微信公众号二维码
咨询织信数字化顾问获取最新资料
数字化咨询热线
400-185-5850
申请预约演示
立即与行业专家交流