C语言植物大战数据结构二叉树递归

目录
  • 前言
  • 一、二叉树的遍历算法
    • 1.构造二叉树
    • 2.前序遍历(递归图是重点.)
    • 3.中序遍历
    • 4.后序遍历
  • 二、二叉树遍历算法的应用
    • 1.求节点个数
    • 3.求第k层节点个数
    • 4.查找值为x的节点
    • 5.二叉树销毁
    • 6.前序遍历构建二叉树
    • 7.判断二叉树是否是完全二叉树
    • 8.求二叉树的深度
  • 三、二叉树LeetCode题目
    • 1.单值二叉树
    • 2. 检查两颗树是否相同
    • 3. 对称二叉树
    • 4.另一颗树的子树
    • 6.反转二叉树

" 梧桐更兼细雨,到黄昏、点点滴滴。"

C语言朱武大战数据结构专栏

C语言植物大战数据结构快速排序图文示例

C语言植物大战数据结构希尔排序算法

C语言植物大战数据结构堆排序图文示例

前言

本篇用C语言递归来实现二叉树的基本操作。主要用到分治思想

1.本篇文章和代码旨在用于链式二叉树基本操作的复习。主要是递归的应用。

2.深刻理解二叉树是递归定义的这一概念。

分治递归思想:

1.把大问题分割为不可再分割的子问题。。

2.然后一步一步的返回

一、二叉树的遍历算法

二叉树的精髓在于遍历。遍历掌握了后,剩下的问题迎刃而解。

1.构造二叉树

“工欲善其事必利其器”

1.所以先创建一个结构体。

2.手动先构造一颗如图所示的二叉树。

typedef int BTDataType;//定义二叉树结构体typedef struct BinaryTreeNode{<!--{C}%3C!%2D%2D%20%2D%2D%3E-->int data;//节点数据struct BinartTreeNode* left;//左子树struct BinartTreeNode* right;//右子树}BTNode;//构造一棵二叉树BTNode* BuyBTNode(BTDataType x){<!--{C}%3C!%2D%2D%20%2D%2D%3E-->BTNode* node = (BTNode*)malloc(sizeof(BTNode));if (node == NULL){<!--{C}%3C!%2D%2D%20%2D%2D%3E-->printf("malloc fail\n");exit(-1);}node->data = x;node->left = NULL;node->right = NULL;return node;}BTNode* CreatBinaryTree(){<!--{C}%3C!%2D%2D%20%2D%2D%3E-->BTNode* node1 = BuyBTNode(1);BTNode* node2 = BuyBTNode(2);BTNode* node3 = BuyBTNode(3);BTNode* node4 = BuyBTNode(4);BTNode* node5 = BuyBTNode(5);BTNode* node6 = BuyBTNode(6);node1->left = node2;node1->right = node4;node2->left = node3;node4->left = node5;node4->right = node6;return node1;}int main(){<!--{C}%3C!%2D%2D%20%2D%2D%3E-->BTNode* tree = CreatBinaryTree();return 0;}typedef int BTDataType;
//定义二叉树结构体
typedef struct BinaryTreeNode
{
	int data;//节点数据
	struct BinartTreeNode* left;//左子树
	struct BinartTreeNode* right;//右子树
}BTNode;
//构造一棵二叉树
BTNode* BuyBTNode(BTDataType x)
{
	BTNode* node = (BTNode*)malloc(sizeof(BTNode));
	if (node == NULL)
	{
		printf("malloc fail\n");
		exit(-1);
	}
	node->data = x;
	node->left = NULL;
	node->right = NULL;
	return node;
}
BTNode* CreatBinaryTree()
{
		BTNode* node1 = BuyBTNode(1);
		BTNode* node2 = BuyBTNode(2);
		BTNode* node3 = BuyBTNode(3);
		BTNode* node4 = BuyBTNode(4);
		BTNode* node5 = BuyBTNode(5);
		BTNode* node6 = BuyBTNode(6);
		node1->left = node2;
		node1->right = node4;
		node2->left = node3;
		node4->left = node5;
		node4->right = node6;
		return node1;
}
int main()
{
	BTNode* tree = CreatBinaryTree();
	return 0;
}

2.前序遍历(递归图是重点.)

遍历顺序:根 左子树 右子树

思路:

1.把每个节点都想成是一棵树。

2.当树为空时。

3.当树不为空时,先遍历左子树,后遍历右子树

注意:前中后序遍历不同处只在printf打印的顺序的位置。

// 二叉树前序遍历
void PreOrder(BTNode* root)
{
	if (root == NULL)
	{
		printf("NULL ");
		return;
	}
	//打印在前
	printf("%d ", root->data);
	PreOrder(root->left);
	PreOrder(root->right);
}

打印结果:

1 2 3 NULL NULL NULL 4 5 NULL NULL 6 NULL NULL

递归分析图:

递归题目的万能的解法。就是画递归图。

二叉树的所有题目,假如你不会,赶快 画递归图 吧

由于递归太庞大,图片太小看不清,所以我把左子树和右子树分开又截了图

1.红线部分代表压栈递归。

2.绿线部分代表 返回

左子树

右子树

3.中序遍历

遍历顺序:左子树 根 右子树

void InOrder(BTNode* root)
{
	if (root == NULL)
	{
		printf("NULL ");
		return;
	}
	InOrder(root->left);
	//打印在中间
	printf("%d ", root->data);
	InOrder(root->right);
}

打印结果

NULL 3 NULL 2 NULL 1 NULL 5 NULL 4 NULL 6 NULL

4.后序遍历

遍历顺序:左子树 右子树 根

void PostOrder(BTNode* root)
{
	if (root == NULL)
	{
		printf("NULL ");
		return;
	}
	PostOrder(root->left);
	PostOrder(root->right);
	//打印在最后
	printf("%d ", root->data);
}

打印结果

NULL NULL 3 NULL 2 NULL NULL 5 NULL NULL 6 4 1

5.层序遍历

思路:

借助先进先出的性质,上一层节点出的时候,带下一层的节点进去。

1.先把根入队列。

2.根节点出来的时候,左右孩子进去。

// 层序遍历
void LevelOrder(BTNode* root)
{
	//初始化队列,注意队列里面存的是 指针类型。
	Queue q;
	QueueInit(&q);
	//如果树不为空开始入队
	if (root)
	{
		QueuePush(&q, root);
	}
	//树不为空开始出对头数据,同时入队左子树和右子树,直到队列为空。
	while (!QueueEmpty(&q))
	{
		BTNode* front = QueueFront(&q);
		QueuePop(&q);
		printf("%d ", front->data);
		//如果还有左右子树,继续入队,否则不入队
		if (front->left)
		{
			QueuePush(&q, front->left);
		}
		if (front->right)
		{
			QueuePush(&q, front->right);
		}
	}
	//记得销毁队列
	printf("\n");
	QueueDestory(&q);
}

二、二叉树遍历算法的应用

1.求节点个数

思想:把大问题逐步分割为子问题。

思路:

1.树为空时返回0个节点。(树为空不意味着才开始就是空树,而是递归到最后一个为NULL的树返回)

2.树不为空时返回自己的1个节点+上一颗树返回的节点的个数。

// 二叉树节点个数
int BinaryTreeSize(BTNode* root)
{
	//当树为空时
	if (root == NULL)
		return 0;
	//当树不为空时
	return BinaryTreeSize(root->left) +
		BinaryTreeSize(root->right) + 1;
}

2.求叶子节点个数

思路:

1.树为NULL时,返回0.

2.两颗子树都不为NULL时,返回1.

3.不满足以上两种情况,继续递归左右子树。

// 二叉树叶子节点个数
int BinaryTreeLeafSize(BTNode* root)
{
	//当树为空时
	if (root == NULL)
		return 0;
	//当两棵 子 树都为空时
	if (root->left == NULL && root->right == NULL)
		return 1;
	/*程序都到这一行, 意味着树不满足返回的情况,
	所以继续递归 左子树和 右子树。*/
	return BinaryTreeLeafSize(root->left)+
		BinaryTreeLeafSize(root->right);
}

3.求第k层节点个数

思想:求上图第3层节点个数。

1.站在第1层来看,就是求第3层节点的个数

2.站在第2层的角度来看,就是求第2层节点的个数

3.站在第3层的角度来看,就是求第1层节点的个数

思路:

1.当树为空时返回0

2.当k为1时返回1。

3.不满足1和2,继续递归左右子树。

// 二叉树第k层节点个数
int BinaryTreeLevelKSize(BTNode* root, int k)
{
	//当树为空时
	if (root == NULL)
		return 0;
	//当k为1时
	if (k == 1)
		return 1;
	//程序能走到这一行,说明树不为空,k也不为1.继续递归
	return BinaryTreeLevelKSize(root->left, k-1)+
	BinaryTreeLevelKSize(root->right, k - 1);
}

4.查找值为x的节点

思想:

1.把最小规模的问题写在最前面作为限制

2.不满足最小规模的问题,则继续递归。将问题一步一步拆分为不可分割的子问题。

// 二叉树查找值为x的节点
BTNode* BinaryTreeFind(BTNode* root, BTDataType x)
{
	//当树为空时
	if (root == NULL)
		return NULL;
	//当树的值等于x时
	if (root->data == x)
		return root;
	/*走到这一行,说明不满足以上条件。
	开始递归左右子树,如果找到了,直接一步一步往回返*/
	BTNode* a = BinaryTreeFind(root->left, x);
	if (a)
	{
		return a;
	}
	BTNode* b = BinaryTreeFind(root->right, x);
	if (b)
	{
		return b;
	}
	//没有x,则返回空
	return NULL;
}

5.二叉树销毁

思路:相当于二叉树的后序遍历。

先把左右子树遍历完后,开始遍历根,对根进行free。

// 二叉树销毁
void BinaryTreeDestory(BTNode* root)
{
	if (root == NULL)
		return;
	BinaryTreeDestory(root->left);
	BinaryTreeDestory(root->right);
	//free掉根
	free(root);
}

6.前序遍历构建二叉树

思路:

对一串字符进行先序遍历,递归遍历二叉树,当遇见#时开始返回 连接 树。

通过前序遍历的数组"ABD##E#H##CF##G##"构建二叉树

#include <stdio.h>
#include <stdlib.h>
typedef struct BTNodeTree
{
    struct BTNodeTree* left;
    struct BTNodeTree* right;
    char val;
}BTNode;
//创建二叉树
BTNode* CreateTree(char* a, int* pi)
{
	//如果树为#则返回null
    if(a[*pi] == '#')
    {
        (*pi)++;
        return NULL;
    }
    //否则构建节点,同时让pi++,以便继续递归
    BTNode* root = (BTNode*)malloc(sizeof(BTNode));
    root->val = a[(*pi)++];
    //构建左右子树
    root->left = CreateTree(a, pi);
    root->right = CreateTree(a, pi);
    //构建完后返回根节点。
    return root;
}
//中序遍历打印。
void inorder(BTNode* root)
{
    if(root == NULL)
        return;
    inorder(root->left);
    printf("%c ", root->val);
    inorder(root->right);
}
int main()
{
    char a[100];
    scanf("%s", a);
    int i = 0;
    BTNode* tree = CreateTree(a, &i);
    inorder(tree);
    return 0;
}

7.判断二叉树是否是完全二叉树

思路:

1.层序遍历,空节点也进队列

2.出到空节点以后,出队列中所有数据,如果全是空,则是完全二叉树

8.求二叉树的深度

思路:二叉树的最大深度等价于:左右子树的最大深度 + 1

int maxDepth(struct TreeNode* root)
{
    if(root == NULL)
    {
        return 0;
    }
    size_t left = maxDepth(root->left) + 1;
    size_t right = maxDepth(root->right) + 1;
    if(right > left)
    {
        return right;
    }
    return left;
}
//判断二叉树是否是完全二叉树
bool BTreeComplete(BTNode* root)
{
	Queue q;
	QueueInit(&q);
	if (root)
		QueuePush(&q, root);
	while (!QueueEmpty(&q))
	{
		BTNode* front = QueueFront(&q);
		QueuePop(&q);
		if (front == NULL)
			break;
		QueuePush(&q, front->left);
		QueuePush(&q, front->right);
	}
	while (!QueueEmpty(&q))
	{
		BTNode* front = QueueFront(&q);
		QueuePop(&q);
		//空后面出到非空,那说明不是完全二叉树
		if (front)
			return false;
	}
	//否则是完全二叉树
	return true;
}

三、二叉树LeetCode题目

以下题目均属于LeetCode的 简单 题目

1.单值二叉树

如果二叉树每个节点都具有相同的值,那么该二叉树就是单值二叉树。

只有给定的树是单值二叉树时,才返回 true;否则返回 false。

思想:

1.看一棵树的三个部分是否相同,相同则继续递归下一颗树,直到树为空。

bool isUnivalTree(struct TreeNode* root)
{
    //当树为空时。
    if(root == NULL)
    {
        return true;
    }
    //当右树不为空,并且 根 != 左树
    //当右树不为空,并且 根 != 右树时
    if(root->left != NULL && root->val != root->left->val)
    return false;
    if(root->right != NULL && root->val != root->right->val)
    return false;
    //能走到这一行,说明第一层树的值相同了。接着递归左右子树。
    return isUnivalTree(root->left) &&
            isUnivalTree(root->right);
}

2. 检查两颗树是否相同

给你两棵二叉树的根节点 p 和 q ,编写一个函数来检验这两棵树是否相同。

bool isSameTree(struct TreeNode* p, struct TreeNode* q)
{
    //当两树都为空时
    if(p == NULL && q== NULL)
        return true;
    //当其中一个树为空时
    if(p == NULL || q == NULL)
        return false;
    //走到这里说明两树存在,比较两树的值
    if(p->val != q->val)
        return false;
    //走到这里说明两树的根节点相同,继续递归,直到判断完左右子树为止。
    return isSameTree(p->left, q->left)
    && isSameTree(p->right, q->right);
}

3. 对称二叉树

给你一个二叉树的根节点 root , 检查它是否轴对称。

bool isSym(struct TreeNode* q, struct TreeNode* p)
{
      //当只有一个根节点时
    if(q == NULL && p == NULL)
         return true;
    //当其中一个子树为空时
    if(q == NULL ||p ==NULL)
         return false;
    //程序走到一这行,说明左右节点存在。当两个根节点不相等时
    if(q->val != p->val)
    return false;
    //走到这一步说明左右节点相同,开始递归左右子树
    return isSym(q->left, p->right) && isSym(q->right, p->left);
}
bool isSymmetric(struct TreeNode* root)
{
    //当是空树时
    if(root == NULL)
        return true;
    return isSym(root->left, root->right);
}

4.另一颗树的子树

思路:

用到了上一题判断两棵树是否相同的思想。

bool isSameTree(struct TreeNode* p, struct TreeNode* q)
{
    //当两树都为空时
    if(p == NULL && q== NULL)
        return true;
    //当其中一个树为空时
    if(p == NULL || q == NULL)
        return false;
    //走到这里说明两树存在,比较两树的值
    if(p->val != q->val)
        return false;
    //走到这里说明两树的根节点相同,继续递归
    return isSameTree(p->left, q->left)
    && isSameTree(p->right, q->right);
}
bool isSubtree(struct TreeNode* root, struct TreeNode* subRoot)
{
    //递归结束条件。当根为空时,并不是说明没有节点,可能是所有的子树都遍历过了。然后不相等返回false
    if(root == NULL)
    return false;
//走到这里说明子树不为空,开始比较子树和sub相同不。
    bool a = isSameTree(root, subRoot);
    if(a)
    return a;
    //走到这里说明不相同,继续递归左子树和右子树,其中一个相同就返回true。
    return isSubtree(root->left, subRoot) || isSubtree(root->right, subRoot);
}

5.二叉树的前序遍历

题目思路

1.求节点个数,开辟数组大小。

2.前序遍历存放到数组中

 int treeSize(struct TreeNode* root)
 {
     if(root == NULL)
        return 0;
     return treeSize(root->left) + treeSize(root->right)+1;
 }
 void preorder(int* a, struct TreeNode* root, int* i)
 {
     if(root == NULL)
     {
          return;
     }
     a[(*i)++] = root->val;
     preorder(a,root->left, i);
     preorder(a,root->right, i);
 }
int* preorderTraversal(struct TreeNode* root, int* returnSize)
{
    //计算树有几个节点,然后开辟相应的空间
    int size = treeSize(root);
    int* a = (int*)malloc(sizeof(int)* size);
    int i = 0;//设置下标i
    *returnSize = size;//需要返回的数组大小
    //前序遍历依次存放到数组中。
    preorder(a, root, &i);
    return a;
}

6.反转二叉树

给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

我犯的BUG:只是对二叉树里面的值进行交换,但是无法避免空指针。一直都是空指针的错误,因为root总会为空,root->data总会遇见空指针

所以以后尽量要多想着交换地址。

void _invertTree(struct TreeNode* root)
{
    if(root)
    {
        struct TreeNode* tmp = root->left;
        root->left = root->right;
        root->right = tmp;
        _invertTree(root->left);
        _invertTree(root->right);
    }
}
struct TreeNode* invertTree(struct TreeNode* root)
{
    _invertTree(root);
    return root;
}

以上就是C语言植物大战数据结构二叉树递归的详细内容,更多关于C语言二叉树递归的资料请关注我们其它相关文章!

(0)

相关推荐

  • C语言二叉树常见操作详解【前序,中序,后序,层次遍历及非递归查找,统计个数,比较,求深度】

    本文实例讲述了C语言二叉树常见操作.分享给大家供大家参考,具体如下: 一.基本概念 每个结点最多有两棵子树,左子树和右子树,次序不可以颠倒. 性质: 1.非空二叉树的第n层上至多有2^(n-1)个元素. 2.深度为h的二叉树至多有2^h-1个结点. 满二叉树:所有终端都在同一层次,且非终端结点的度数为2. 在满二叉树中若其深度为h,则其所包含的结点数必为2^h-1. 完全二叉树:除了最大的层次即成为一颗满二叉树且层次最大那层所有的结点均向左靠齐,即集中在左面的位置上,不能有空位置. 对于完全二叉

  • C语言数据结构之二叉树的非递归后序遍历算法

    C语言数据结构之二叉树的非递归后序遍历算法 前言: 前序.中序.后序的非递归遍历中,要数后序最为麻烦,如果只在栈中保留指向结点的指针,那是不够的,必须有一些额外的信息存放在栈中. 方法有很多,这里只举一种,先定义栈结点的数据结构 typedef struct{Node * p; int rvisited;}SNode //Node 是二叉树的结点结构,rvisited==1代表p所指向的结点的右结点已被访问过. lastOrderTraverse(BiTree bt){ //首先,从根节点开始,

  • c语言版本二叉树基本操作示例(先序 递归 非递归)

    复制代码 代码如下: 请按先序遍历输入二叉树元素(每个结点一个字符,空结点为'='):ABD==E==CF==G== 先序递归遍历:A B D E C F G中序递归遍历:D B E A F C G后序递归遍历:D E B F G C A层序递归遍历:ABCDEFG先序非递归遍历:A B D E C F G中序非递归遍历:D B E A F C G后序非递归遍历:D E B F G C A深度:请按任意键继续. . . 复制代码 代码如下: #include<stdio.h>#include&

  • C语言二叉树的非递归遍历实例分析

    本文以实例形式讲述了C语言实现二叉树的非递归遍历方法.是数据结构与算法设计中常用的技巧.分享给大家供大家参考.具体方法如下: 先序遍历: void preOrder(Node *p) //非递归 { if(!p) return; stack<Node*> s; Node *t; s.push(p); while(!s.empty()) { t=s.top(); printf("%d\n",t->data); s.pop(); if(t->right) s.pus

  • C语言非递归后序遍历二叉树

    本文实例为大家分享了C语言非递归后序遍历二叉树的具体代码,供大家参考,具体内容如下 法一:实现思路:一个栈 先按 根->右子树->左子树的顺序访问二叉树.访问时不输出.另一个栈存入前一个栈只进栈的结点. 最后输出后一个栈的结点数据. #include<stdio.h> #include<stdlib.h> typedef struct TreeNode{ char element; struct TreeNode *left,*right; }Tree,*BTree;

  • C语言植物大战数据结构二叉树递归

    目录 前言 一.二叉树的遍历算法 1.构造二叉树 2.前序遍历(递归图是重点.) 3.中序遍历 4.后序遍历 二.二叉树遍历算法的应用 1.求节点个数 3.求第k层节点个数 4.查找值为x的节点 5.二叉树销毁 6.前序遍历构建二叉树 7.判断二叉树是否是完全二叉树 8.求二叉树的深度 三.二叉树LeetCode题目 1.单值二叉树 2. 检查两颗树是否相同 3. 对称二叉树 4.另一颗树的子树 6.反转二叉树 " 梧桐更兼细雨,到黄昏.点点滴滴." C语言朱武大战数据结构专栏 C语言

  • C语言植物大战数据结构二叉树堆

    目录 前言 堆的概念 创建结构体 初始化结构体 销毁结构体 向堆中插入数据 1.堆的物理结构和逻辑结构 2.完全二叉树下标规律 3.插入数据思路 依次打印堆的值 删除堆顶的值 判断堆是否为空 求堆中有几个元素 得到堆顶的值 堆排序 总体代码 Heap.h Heap.c Test.c “竹杖芒鞋轻胜马,谁怕?一蓑烟雨任平生” C语言朱武大战数据结构专栏 C语言植物大战数据结构快速排序图文示例 C语言植物大战数据结构希尔排序算法 C语言植物大战数据结构堆排序图文示例 C语言植物大战数据结构二叉树递归

  • C语言植物大战数据结构快速排序图文示例

    目录 快速排序 一.经典1962年Hoare法 1.单趟排序 2.递归左半区间和右半区间 3.代码实现 二.填坑法(了解) 1.单趟思路 2.代码实现 三.双指针法(最佳方法) 1.单趟排序 2.具体思路 3.代码递归图 4.代码实现 四.三数取中优化(最终方案) 1.三数取中 2.代码实现(最终代码) 五.时间复杂度(重点) 1.最好情况下 2.最坏情况下 3.空间复杂度 六.非递归写法 1.栈模拟递归快排 2.队列实现快排 浅浅总结下 “田家少闲月,五月人倍忙”“夜来南风起,小麦覆陇黄” C

  • C语言植物大战数据结构希尔排序算法

    目录 前言 一.插入排序 1.排序思路 2.单趟排序 详细图解 3.整体代码 4.时间复杂度 (1).最坏情况下 (2).最好情况下 (3).基本有序情况下(重点) 5.算法特点 二.希尔排序 1.希尔从哪个方面优化的插入排序? 2.排序思路 3.预排序 4.正式排序 5.整体代码 6.时间复杂度 (1).while循环的复杂度 (2).每组gap的时间复杂度 结论: “至若春和景明,波澜不惊,上下天光,一碧万顷,沙鸥翔集,锦鳞游泳,岸芷汀兰,郁郁青青.” C语言朱武大战数据结构专栏 C语言植物

  • C语言植物大战数据结构堆排序图文示例

    目录 TOP.堆排序前言 一.向下调整堆排序 1.向下调整建堆 建堆的技巧 建堆思路代码 2.向下调整排序 调整思路 排序整体代码 3.时间复杂度(难点) 向下建堆O(N) 向下调整(N*LogN) 二.向上调整堆排序 1.向上调整建堆 2.建堆代码 “大弦嘈嘈如急雨,小弦切切如私语”“嘈嘈切切错杂弹,大珠小珠落玉盘” TOP.堆排序前言 什么是堆排序?假如给你下面的代码让你完善堆排序,你会怎么写?你会怎么排? void HeapSort(int* a, int n) { } int main(

  • C语言数据结构二叉树简单应用

     C语言数据结构二叉树简单应用 在计算机科学中,二叉树是每个节点最多有两个子树的树结构.通常子树被称作"左子树"(left subtree)和"右子树"(right subtree),接下来我就在这里给大家介绍一下二叉树在算法中的简单使用: 我们要完成总共有 (1)二叉树的创建 (2)二叉树的先中后序递归遍历 (3)统计叶子结点的总数 (4)求树的高度 (5)反转二叉树 (6)输出每个叶子结点到根节点的路径 (7)输出根结点到每个叶子结点的路径. 定义二叉树结点类型

  • C语言数据结构二叉树先序、中序、后序及层次四种遍历

    目录 一.图示展示 (1)先序遍历 (2)中序遍历 (3)后序遍历 (4)层次遍历 (5)口诀 二.代码展示 一.图示展示 (1)先序遍历 先序遍历可以想象为,一个小人从一棵二叉树根节点为起点,沿着二叉树外沿,逆时针走一圈回到根节点,路上遇到的元素顺序,就是先序遍历的结果 先序遍历结果为:A B D H I E J C F K G 动画演示: 记住小人沿着外围跑一圈(直到跑回根节点),多看几次动图便能理解 (2)中序遍历 中序遍历可以看成,二叉树每个节点,垂直方向投影下来(可以理解为每个节点从最

  • 数据结构 二叉树的递归与非递归

    数据结构 二叉树的递归与非递归 实例代码: #include <iostream> #include <queue> #include <stack> #include <assert.h> using namespace std; template<class T> struct BinaryTreeNode { BinaryTreeNode<T>* _left; BinaryTreeNode<T>* _right; T

  • C++ 数据结构二叉树(前序/中序/后序递归、非递归遍历)

    C++ 数据结构二叉树(前序/中序/后序递归.非递归遍历) 二叉树的性质: 二叉树是一棵特殊的树,二叉树每个节点最多有两个孩子结点,分别称为左孩子和右孩子. 例: 实例代码: #include <iostream> #include <Windows.h> #include <stack> using namespace std; template <class T> struct BinaryTreeNode { int _data; BinaryTree

  • C语言数据结构二叉树之堆的实现和堆排序详解

    目录 一.本章重点 二.堆 2.1堆的介绍 2.2堆的接口实现 三.堆排序 一.本章重点 堆的介绍 堆的接口实现 堆排序 二.堆 2.1堆的介绍 一般来说,堆在物理结构上是连续的数组结构,在逻辑结构上是一颗完全二叉树. 但要满足 每个父亲节点的值都得大于孩子节点的值,这样的堆称为大堆. 每个父亲节点的值都得小于孩子节点的值,这样的堆称为小堆. 那么以下就是一个小堆. 百度百科: 堆的定义如下:n个元素的序列{k1,k2,ki,…,kn}当且仅当满足下关系时,称之为堆. 若将和此次序列对应的一维数

随机推荐