2.20数据结构与算法学习日记(二叉树第一部分)

2024-02-20 23:04

本文主要是介绍2.20数据结构与算法学习日记(二叉树第一部分),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.树的表示

typedef int DadaType;
struct Node{struct Node* firstChild;struct Node* pnextBrotherDataType data;
};//树的表示

2.二叉树的简介

二叉树是一种树形数据结构,每个节点最多有两个子节点,分别称为左子节点和右子节点。二叉树具有以下特点:

1. 根节点:二叉树的顶端节点称为根节点,它没有父节点。
2. 子节点:每个节点最多有两个子节点,分别称为左子节点和右子节点。
3. 叶节点:没有子节点的节点称为叶节点。
4. 深度:从根节点到某个节点的唯一路径上的节点数称为该节点的深度。
5. 高度:从某个节点到叶节点的最长路径上的节点数称为该节点的高度。
6. 完全二叉树:除了最底层之外,每一层的节点都是满的,并且最底层的节点都靠左排列。
7. 满二叉树:每个节点要么没有子节点,要么有两个子节点。

二叉树可以用来表示表达式、文件系统、数据库索引等各种数据结构和算法问题。常见的二叉树遍历方式有前序遍历、中序遍历和后序遍历。

3.二叉树图例(部分)

1.普通二叉树

普通二叉树是一种最基本的二叉树,每个节点最多有两个子节点,分别称为左子节点和右子节点。普通二叉树没有特定的规则或性质,节点的插入和删除可以任意进行,因此它的形态和结构比较灵活。

以下是一个示例普通二叉树的图示:

```
        1
       / \
      2   3
     / \    / \
    4  5 6  7
```

在这个例子中,这是一个普通二叉树,每个节点最多有两个子节点,节点的插入和删除可以随意进行,没有特定的规则限制。普通二叉树常用于表示一般的树形结构,如文件系统、家谱等。

2.完全二叉树 

完全二叉树是一种特殊的二叉树,除了最底层之外,每一层的节点都是满的,并且最底层的节点都靠左排列。在完全二叉树中,如果某个节点的索引为i(从1开始),则它的左子节点的索引为2i,右子节点的索引为2i+1。

以下是一个示例完全二叉树的图示:

```
        1
       / \
      2   3
     / \    / 
    4  5 6  
```

在这个例子中,这是一个完全二叉树,因为每一层的节点都是满的,除了最底层的节点6之外,其他节点都是靠左排列的。完全二叉树常用于堆数据结构的实现,具有较好的性能特性。

3.满二叉树

满二叉树是一种特殊的二叉树,每个节点要么没有子节点,要么有两个子节点。除了叶节点外,每个节点都有两个子节点。满二叉树的叶节点都在同一层,且所有非叶节点的度都是2。

以下是一个示例满二叉树的图示:

        1
       / \
      2   3
     / \    / \
    4  5 6  7
 

在这个例子中,这是一个满二叉树,每个节点要么没有子节点,要么有两个子节点,所有非叶节点的度都是2。满二叉树在计算机科学中常用于堆数据结构的实现,具有一些特殊的性质和应用。

4.二叉树遍历

1.前序遍历

在前序遍历中,对于任意节点,先访问该根节点,然后递归地对其左子树进行前序遍历,最后递归地对其右子树进行前序遍历。

以下是一个示例二叉树的前序遍历顺序(节点值用数字表示):

        1/ \2   3/ \ / \4  5 6  7

前序遍历的结果为:1, 2, 4, 5, 3, 6, 7。

在这个例子中,前序遍历先访问根节点1,然后递归地对左子树进行前序遍历(2, 4, 5),最后递归地对右子树进行前序遍历(3, 6, 7)。

2.中序遍历

在中序遍历中,对于任意节点,先递归地对其左子树进行中序遍历,然后访问该节点,最后递归地对其右子树进行中序遍历。

以下是一个示例二叉树的中序遍历顺序(节点值用数字表示):

        1
       / \
      2   3
     / \    / \
    4  5 6  7

中序遍历的结果为:4, 2, 5, 1, 6, 3, 7。

在这个例子中,中序遍历先递归地对左子树进行中序遍历(4, 2, 5),然后访问根节点1,最后递归地对右子树进行中序遍历(6, 3, 7)。

3.后序遍历

它的遍历顺序是先递归地对左子树进行后序遍历,然后递归地对右子树进行后序遍历,最后访问根节点。(左,右,根)

在后序遍历中,对于任意节点,先递归地对其左子树进行后序遍历,然后递归地对其右子树进行后序遍历,最后访问该根节点。

以下是一个示例二叉树的后序遍历顺序(节点值用数字表示):

```
        1
       / \
      2   3
     / \    / \
    4  5 6  7
```

后序遍历的结果为:4, 5, 2, 6, 7, 3, 1。

在这个例子中,后序遍历先递归地对左子树进行后序遍历(4, 5, 2),然后递归地对右子树进行后序遍历(6, 7, 3),最后访问根节点1。

代码示例(单纯只是定义了函数)

#include<bits/stdc++.h>
using namespace std;
typedef int DadaType;
struct Node{struct Node* firstChild;struct Node* pnextBrotherDataType data;
};//树的表示
//二叉链
struct binaryTreeNode{struct binaryTreeNode* pleft;struct binaryTreeNode* pright;
}BTnode;
void PreOrder(BTnode *root){//前序遍历(根,左,右)if(root==NULL){printf("NULL");return;}printf("%d",root->data);PreOrder(root->pleft);PreOrder(root->pright);
}
void Inorder(BTnode *root){//中序遍历(左,根,右)if(root==NULL){printf("NULL");return;}Inorder(root->pleft);printf("%d",root->data);Inorder(root->pright);
}
void PostOrder(Btnode *root){//后序遍历(左,右,根)if(root==NULL){printf("NULL");}PostOrder(root->pleft);printf("%d",root->data);PostOrder(root->pright);
}
void destroyOrder(BTnode *root){if(root==NULL){return;}destroyOrder(root->pleft);destroyOrder(root->pright);free(root);root=NULL;
}

这篇关于2.20数据结构与算法学习日记(二叉树第一部分)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/729811

相关文章

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.