返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++树的定义实例分析
  • 591
分享到

C++树的定义实例分析

2023-07-02 12:07:57 591人浏览 安东尼
摘要

这篇文章主要介绍“c++树的定义实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++树的定义实例分析”文章能帮助大家解决问题。概念本文以一个简单的树为例,如下图,来记录树的一些概念。树一种由

这篇文章主要介绍“c++树的定义实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++树的定义实例分析”文章能帮助大家解决问题。

概念

本文以一个简单的树为例,如下图,来记录树的一些概念。

C++树的定义实例分析

一种由n个节点组成的具有一定层次关系的有限数据集合。每个节点有0个或者n个子节点,有一个根节点(没有前驱只有后继),除根节点外每一个节点都有一个前驱,0个或多个后继。

树的叶子节点

只有一个前驱,没有后继的节点,为最外层的节点。叶子节点的度为0。

节点的度

节点拥有的子树的数目。

分支结点

度不为0的结点。

树的度

树中结点的最大的度。

树的高度

任意叶子节点距离根节点的最大深度。此文中树的叶子节点为D、E、H,距离根节点的深度都为4,故高度为4。

树的深度

即从根节点到叶子节点的行数。此文中树的深度为4。

二叉树

二叉树是每个节点最多有两个子树的树结构。

它有五种基本形态:

二叉树可以是空集;

根可以有空的左子树或右子树;

或者左、右子树皆为空。

二叉树的特点

二叉树第i层上的结点数目最多为2i-1(i>=1)

深度为k的二叉树至多有2k-1个结点(k>=1)

包含n个结点的二叉树的高度至少为(log2n)+1

满二叉树

高度为h,并且由2h-1个节点组成的二叉树。

完全二叉树

一棵二叉树中,只有最下面两层节点的度可以小于2,并且最下层的叶节点集中在靠左的若干位置上,这样的二叉树称为完全二叉树。

二叉查找树

二叉查找树又被称为二叉搜索树。设x为二叉查找树中的一个结点,x结点包含关键字key,结点x的key值计为key[x]。如果y是x的左子树中的一个结点,则key[y]<=key[x];如果y是x的右子树的一个结点,则key[y]>=key[x]。

特点:

若任意结点的左子树不空,则左子树上所有结点的值均小于它的根结点的值。

任意结点的右子树不空,则右子树上所有结点的值均大于它的根结点的值。

任意结点的左、右子树也分别为二叉查找树。

没有键值相等的结点。

示例

下面直接上代码,一个简单的树的创建、遍历输出,叶子节点数,高度。

代码实现

Tree.h

#pragma oncetypedef struct MYTREE {char data;struct MYTREE* lChild;struct MYTREE* rChild;}MyTree;class Tree{public:Tree();~Tree();void CreateTree();void TraverseTree(MyTree *root);void GetLeafnode(MyTree *root,int &num);int GetTreeDepth(MyTree *root);void GetTreeNode(MyTree *root, int &num);};

Tree.cpp

#include "Tree.h"#include <iOStream>#include<alGorithm>//max,minusing namespace std;Tree::Tree(){}Tree::~Tree(){}void Tree::CreateTree(){MyTree t1 = {'A',nullptr,nullptr};MyTree t2 = { 'B',nullptr,nullptr };MyTree t3 = { 'C',nullptr,nullptr };MyTree t4 = { 'D',nullptr,nullptr };MyTree t5 = { 'E',nullptr,nullptr };MyTree t6 = { 'F',nullptr,nullptr };MyTree t7 = { 'G',nullptr,nullptr };MyTree t8 = { 'H',nullptr,nullptr };t1.lChild = &t2;t1.rChild = &t6;t2.rChild = &t3;t3.lChild = &t4;t3.rChild = &t5;t6.rChild = &t7;t7.lChild = &t8;TraverseTree(&t1);cout << endl;int leafNum = 0;GetLeafNode(&t1,leafNum);cout << "leaf num: " << leafNum << endl;int treeDepth = GetTreeDepth(&t1);cout << "depth:" << treeDepth << endl;int nodeNum = 0;GetTreeNode(&t1,nodeNum);cout << "node num; " << nodeNum << endl;}void Tree::TraverseTree(MyTree *root){if (root == nullptr){return;}TraverseTree(root->lChild);cout << root->data;TraverseTree(root->rChild);}void Tree::GetLeafNode(MyTree *root,int &num){if (root == nullptr){return ;}if (root->lChild == nullptr && root->rChild == nullptr){num++;}GetLeafNode(root->lChild,num);GetLeafNode(root->rChild,num);}int Tree::GetTreeDepth(MyTree * root){int num = 0;if (root == nullptr){return num;}int lNum = GetTreeDepth(root->lChild);int rNum = GetTreeDepth(root->rChild);return max(lNum,rNum)+1;}void Tree::GetTreeNode(MyTree * root, int & num){if (root == nullptr){return;}++num;GetTreeNode(root->lChild,num);GetTreeNode(root->rChild,num);}

main.cpp

#include <iostream>#include "Tree.h"using namespace std;void test() {Tree t;t.CreateTree();}int main(){test();return 0;}
开发环境

vs2017控制台输出程序。

运行结果

C++树的定义实例分析

关于“C++树的定义实例分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网其他教程频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: C++树的定义实例分析

本文链接: https://www.lsjlt.com/news/341964.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C++树的定义实例分析
    这篇文章主要介绍“C++树的定义实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++树的定义实例分析”文章能帮助大家解决问题。概念本文以一个简单的树为例,如下图,来记录树的一些概念。树一种由...
    99+
    2023-07-02
  • C++树与二叉树实例分析
    这篇“C++树与二叉树实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++树与二叉树实例分析”文章吧。树树的定义Q:...
    99+
    2023-06-30
  • C++引用的定义与使用实例分析
    这篇文章主要介绍了C++引用的定义与使用实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C++引用的定义与使用实例分析文章都会有所收获,下面我们一起来看看吧。解释引用首先我们先来看一个引用的例子int&n...
    99+
    2023-07-02
  • C++二叉搜索树实例分析
    本篇内容介绍了“C++二叉搜索树实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!独一无二的二叉搜索树Given an integer&...
    99+
    2023-06-19
  • C++的定义,声明和初始化实例分析
    这篇文章主要介绍了C++的定义,声明和初始化实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C++的定义,声明和初始化实例分析文章都会有所收获,下面我们一起来看看吧。定义变量的定义用于为变量分配存储空间,...
    99+
    2023-06-29
  • C语言树状数组与线段树实例分析
    这篇文章主要介绍“C语言树状数组与线段树实例分析”,在日常操作中,相信很多人在C语言树状数组与线段树实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C语言树状数组与线段树实例分析”的疑惑有所帮助!接下来...
    99+
    2023-06-30
  • C++中红黑树的示例分析
    这篇文章将为大家详细讲解有关C++中红黑树的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。红黑树红黑树的概念红黑树的概念 红黑树,是一种二叉搜索树,但在每个结点上增加一个存储位表示结点的颜色,可以...
    99+
    2023-06-29
  • C++二叉树层序遍历实例分析
    今天小编给大家分享一下C++二叉树层序遍历实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。二叉树层序遍历Example...
    99+
    2023-06-19
  • JavaScript对象定义与实例分析
    本文小编为大家详细介绍“JavaScript对象定义与实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript对象定义与实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起...
    99+
    2024-04-02
  • phpunit自定义的示例分析
    这篇文章主要介绍phpunit自定义的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!下载:wget  https://phar.phpunit.de/ph...
    99+
    2024-04-02
  • Android编程自定义Notification实例分析
    本文实例讲述了Android编程自定义Notification的用法。分享给大家供大家参考,具体如下: Notification是一种让你的应用程序在不使用Activity的情...
    99+
    2022-06-06
    notification Android
  • C#单例模式引起的自定义异常举例分析
    本篇内容主要讲解“C#单例模式引起的自定义异常举例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#单例模式引起的自定义异常举例分析”吧!案例代码对于单例模式,C#有个简洁的实现,采用静态的...
    99+
    2023-06-17
  • C语言中二叉树的示例分析
    这篇文章主要为大家展示了“C语言中二叉树的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C语言中二叉树的示例分析”这篇文章吧。树概念及结构树是一种 非线性 的数据结构,它是由 n ( n...
    99+
    2023-06-29
  • HTML元素定义的示例分析
    这篇文章将为大家详细讲解有关HTML元素定义的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 HTML 文档由 HTML 元素定义。 HTML 元素 开始标...
    99+
    2024-04-02
  • Java抽象定义的示例分析
    小编给大家分享一下Java抽象定义的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、概述在OOP这个概念中,所有的对象都是通过类来描述的;但是并不是所有...
    99+
    2023-06-14
  • php定义数组的示例分析
    这篇文章主要介绍了php定义数组的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。PHP开发环境搭建工具有哪些一、phpStudy,是一个新手入门最常用的开发环境。二、...
    99+
    2023-06-14
  • C++11中模板隐式实例化与显式实例化的定义详解分析
    目录1. 隐式实例化2. 显式实例化声明与定义3. 显式实例化的用途1. 隐式实例化 在代码中实际使用模板类构造对象或者调用模板函数时,编译器会根据调用者传给模板的实参进行模板类型推...
    99+
    2024-04-02
  • C++使用LeetCode实现二叉搜索树的示例分析
    这篇文章将为大家详细讲解有关C++使用LeetCode实现二叉搜索树的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Given an integer n, generate all st...
    99+
    2023-06-20
  • python开发之函数定义实例分析
    本文实例讲述了python开发之函数定义方法。分享给大家供大家参考,具体如下: 下面是我做的几个用列: #python中的函数定义,使用和传参 def_str = ''' python中的函数以如下...
    99+
    2022-06-04
    函数 实例 定义
  • C语言平衡二叉树的示例分析
    这篇文章给大家分享的是有关C语言平衡二叉树的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。平衡二叉树(Balanced Binary Tree)又被称为AVL树(有别于AVL算法),且具有以下性质:它是一...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作