当前位置: 首页 > news >正文

网站开发弹窗制作如何做线上销售和推广

网站开发弹窗制作,如何做线上销售和推广,河南疫情防控最新消息,潍坊专业java培训报名文章目录 前言一、普通二叉树的链式结构二、 造树三、普通二叉树的遍历四、遍历完整代码五、总结 前言 本篇文章笔者将会对普通二叉树部分进行细致的讲解 , 本篇主要包括以下内容: 二叉树链式结构的介绍 ,二叉树的遍历. 笔者会一步一步分析带学者领略递归的美好~~ 一、普通二叉…

文章目录

  • 前言
  • 一、普通二叉树的链式结构
  • 二、 造树
  • 三、普通二叉树的遍历
  • 四、遍历完整代码
  • 五、总结


前言

本篇文章笔者将会对普通二叉树部分进行细致的讲解 , 本篇主要包括以下内容: 二叉树链式结构的介绍 ,二叉树的遍历. 笔者会一步一步分析带学者领略递归的美好~~


一、普通二叉树的链式结构

在前面章节中 , 笔者对特殊二叉树部分进行了讲解, 特殊二叉树是基于数组实现的 ,但对于普通二叉树来说就要使用链式结构来实现了 ,以下将具体介绍 !

那么什么是链式结构呢 ? 这里就好比如链表 , 是一个一个节点组成. 这里笔者推荐一种特殊方法 : 左孩子 , 右兄弟表示法 .

左孩子右兄弟表示法

顾名思义: 我们要定义两个指针 , 一个指向左孩子 , 一个指向右孩子(左孩子的右兄弟).

左孩子右兄弟表示图
链式结构表示法

// 普通二叉树typedef int OrdBinTreeDataType;// 普通二叉树的链式声明
typedef struct OrdBinTree
{OrdBinTreeDataType data;struct OrdBinTree* Left;struct OrdBinTree* Right;
}OBTree;

二、 造树

在当前阶段 , 笔者建议学者采用 " 手动造树 " 的方法 , 这种方法同样也是我们在遇到一些相关OJ问题时可以采用的一种寻找问题的方法 .

手动造树

typedef int OrdBinTreeDataType;// 普通二叉树的链式声明
typedef struct OrdBinTree
{OrdBinTreeDataType data;struct OrdBinTree* Left;struct OrdBinTree* Right;
}OBTree;//手动造树
OBTree* ByNode(int x)
{OBTree* node = (OBTree*)malloc(sizeof(OBTree));if (node == NULL){perror("malloc fail! ");return NULL;}node->data = x;node->Left = node->Right = NULL;return node;
}OBTree* CreatTree()
{OBTree* node1 = ByNode(1);OBTree* node2 = ByNode(2);OBTree* node3 = ByNode(3);OBTree* node4 = ByNode(4);OBTree* node5 = ByNode(5);OBTree* node6 = ByNode(6);//连接node1->Left = node2;node1->Right = node4;node2->Left = node3;node4->Left = node5;node4->Right = node6;return node1;}

当树造好了以后就可以开始学习 , 树的遍历相关知识了 .


三、普通二叉树的遍历

分类

这里讨论 : 前序遍历 , 中序遍历 , 后序遍历 , 层序遍历 .
这里笔者介绍前三种~

首先 , 这里的 前 , 中 , 后 , 指的是位置是 : 前 , 中 , 后.

在实现这些变量之前 , 笔者介绍一种方法 , 分支递归

实现思想

首选 , 对于二叉树我们知道二叉树是由递归定义的 , 所以在普通二叉树中可以采用递归的思想来进行, 递归 : 大问题化小问题 ,直至问题解决 .

其次, 任何一颗树都是由根节点和子树构成 , 这是分支递归的核心 !

树的分支递归思想
这里 , 理解递归的概念 : 递则往下一层一层递 , 归则往回一层一层归. 也就是说 : 每次的归只能归回该函数的上一层. (这是极其重要的 !)

递归解释图:

在这里插入图片描述
那么什么是分支递归, 其实就是逐渐拆解成小问题得递归 , 以下将会有所体会 ~~

实现

前序遍历

形式: 根 , 左节点 , 右节点 . (遍历顺序) . 遇到空树才停止 " 递 ".

这里笔者先给出前序遍历代码 ,以便学者理解 !

代码

//前序遍历
void PreOrder(OBTree* tree)
{if (tree == NULL){printf("NULL ");return;}printf("%d ", tree->data); // 根PreOrder(tree->Left); //左孩子PreOrder(tree->Right); //右孩子}

访问顺序 :

在这里插入图片描述

  1. 访问到 - 1 的位置
  2. 访问绿色左树 , 但绿色左树不为空 , 则继续向下访问 .
  3. 访问绿色部分的 - 2 的位置
  4. 访问红色部分 , 但红色左树不为空 , 则继续向下访问 .
  5. 访问红色部分的 - 3 的位置
  6. 访问蓝色部分 , 蓝色部分为 , 则停止 ’ 递 ’ .

! 蓝色数字部分为优先访问的节点值 !

递过程的打印

因为此为前序遍历 , 故每一次递是先访问根的 , 根据以上代码 , 则 : 会优先打印出
1 2 3
在这里插入图片描述
那么右边分析同上即可.

在这里插入图片描述

详细流程

在这里插入图片描述
每一个节点的递归与其一样 , 同样分析即可 !

递归展开图

在这里插入图片描述
在这里插入图片描述
执行完以上过程 , 则最终打印结果为 :

最终打印结果
在这里插入图片描述

中序遍历

经过以上细致的分析 ,相信学者对遍历有所认识 , 那么中序 , 后序就显得特别简单了, 无非就是根的位置不同的区别

代码

//中序遍历
void InOrder(OBTree* tree)
{if (tree == NULL){printf("NULL ");return;}InOrder(tree->Left);printf("%d ", tree->data); InOrder(tree->Right);
}

结果

中序

后序遍历

//后序遍历
void AfterOrder(OBTree* tree)
{if (tree == NULL){printf("NULL ");return;}AfterOrder(tree->Left);AfterOrder(tree->Right);printf("%d ", tree->data);}

结果

在这里插入图片描述


四、遍历完整代码

#define  _CRT_SECURE_NO_WARNINGS#include <stdio.h>#include <stdlib.h>
//树的遍历
typedef int OrdBinTreeDataType;// 普通二叉树的链式声明
typedef struct OrdBinTree
{OrdBinTreeDataType data;struct OrdBinTree* Left;struct OrdBinTree* Right;
}OBTree;//手动造树
OBTree* ByNode(int x)
{OBTree* node = (OBTree*)malloc(sizeof(OBTree));if (node == NULL){perror("malloc fail! ");return NULL;}node->data = x;node->Left = node->Right = NULL;return node;
}OBTree* CreatTree()
{OBTree* node1 = ByNode(1);OBTree* node2 = ByNode(2);OBTree* node3 = ByNode(3);OBTree* node4 = ByNode(4);OBTree* node5 = ByNode(5);OBTree* node6 = ByNode(6);//连接node1->Left = node2;node1->Right = node4;node2->Left = node3;node4->Left = node5;node4->Right = node6;return node1;}//前序遍历
void PreOrder(OBTree* tree)
{if (tree == NULL){printf("NULL ");return;}printf("%d ", tree->data); // 根PreOrder(tree->Left); //左孩子PreOrder(tree->Right); //右孩子}//中序遍历
void InOrder(OBTree* tree)
{if (tree == NULL){printf("NULL ");return;}InOrder(tree->Left);printf("%d ", tree->data); InOrder(tree->Right);
}//后序遍历
void AfterOrder(OBTree* tree)
{if (tree == NULL){printf("NULL ");return;}AfterOrder(tree->Left);AfterOrder(tree->Right);printf("%d ", tree->data);}
int main()
{OBTree* tree = CreatTree();printf("前序: \n");PreOrder(tree);printf("\n");printf("中序: \n");InOrder(tree);printf("\n");printf("后序: \n");AfterOrder(tree);printf("\n");return 0;}

在这里插入图片描述


五、总结

以上是对二叉树的遍历的讲解 ,其实就是对递归的深入 ,相信大家通过学习会有所收获 !

http://www.dt0577.cn/news/30325.html

相关文章:

  • 外贸建站推广公司站长之家网站模板
  • 网站建设项目需求分析报告网站换了域名怎么查
  • 营业执照申请网站seo搜索引擎优化业务
  • 杭州市建设工程招标信息网seo单页面优化
  • 做网站收入太低seo点击排名软件哪家好
  • 各种网站建设报价seo免费外链工具
  • 网站图片如何优化百度收录站长工具
  • 北京网站改版有哪些好处茂名网站建设制作
  • 微信手机网站设计邀请推广app
  • 网站轮播广告代码哪个网站做推广效果好
  • 做阿里网站需要的faq营销渠道策略
  • java web网站开发框架最有吸引力的营销模式
  • wordpress captcha网站seo综合诊断
  • cho菌主题wordpressseo的搜索排名影响因素有
  • 博客网站怎么做cpa建立网站的基本步骤
  • 先做网站再付款百度经验官网首页
  • 城口自助建站电脑培训机构哪个好
  • 中国制造网外贸平台网址搜索优化的培训免费咨询
  • 51做网站微营销平台
  • 怎么给网站做404界面推广方案是什么
  • 网站开发好学吗中国网站建设公司
  • 做数据新闻的网站有哪些方面bittorrentkitty磁力猫
  • 企业登录官网seo攻略
  • 门户网站建设 考核百度有钱花人工客服
  • 2h1g做视频网站微商推广哪家好
  • 重庆哪家做网站广东疫情最新通报
  • 莆田交友网站服务app开发成本预算表
  • 网站建设worldpress软文是什么文章
  • 十大收益最好的自媒体平台湖南企业竞价优化
  • 手机网站设计建设服务bt磁力狗