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

济宁b2b网站建设服务东莞做网站的公司吗

济宁b2b网站建设服务,东莞做网站的公司吗,在一家传媒公司做网站编辑 如何,企业所得税20241.知识总览 一般的树会有多个孩子,所以存储结构也会与二叉树略有不同。 一般树的遍历。 2.双亲表示法 双亲表示法,也是父亲表示法,即每个节点中都存储了其父节点的地址信息。 特性:可以轻易地找到父节点,但寻找孩子节…

1.知识总览

7e0e866cea694b068d411560e901c8be.png

        一般的树会有多个孩子,所以存储结构也会与二叉树略有不同。

        一般树的遍历。

2.双亲表示法

        双亲表示法,也是父亲表示法,即每个节点中都存储了其父节点的地址信息。

        特性:可以轻易地找到父节点,但寻找孩子节点麻烦。

        顺序储存,每个节点都储存有其对应的父节点数组下标,根节点默认为-1(且在顺序表中,只有下标为0,其内存有-1的节点是根结点)。

        i.代码

//定义树最多有多少节点
# define MAX 10
//定义树的节点
class PTNode
{
public://数据元素int data;//父节点位置域int parent;
};
//定义树
class PTree
{
public:PTNode nodes[MAX];//指示当前节点个数int n;
};

        删除节点的思路:

        法一,将待删除节点储存的父节点下标设置为-1,意指该节点为空。

        法二,将数组最末尾的节点覆盖到待删除节点的位置,该法更优,可以保证前n个节点都是有意义的。

        在删除过程中,如果删除的节点还有孩子,那么,其实是在删除以它为根的子树,此时就需要查询到这个子树包含的所有节点,很显然,这需要非常麻烦的遍历,非必要不用顺序存储。

3.孩子表示法

        顺序+链式存储,用数组储存所有节点,在节点内部用链式结构储存与它直接相连的孩子节点下标(没有孩子的孩子,没有孙子辈的)。

        特性:找孩子简单,找父亲难。

        i.代码

//链表节点的结构
class CTNode
{
public://孩子节点在数组中的位置int child;//下一个节点(下一个儿子,不是孙子)CTNode* next;
};
//包含链表的节点
class CTBox
{
public://数据int data;//第一个孩子CTNode* firstChild;
};
//树
class CTree
{
public:CTBox nodes[MAX];//指示已有节点数和根节点的位置int n, r;
};

        同样也有一个弊端,就是难以找到双亲。

4.孩子兄弟表示法

        此法为链式存储,旨在把一般树转化为二叉树存储,这也是最重要的方法。

        节点中,有两个指针,一个指示自己的第一个孩子(是否有孩子),一个指示自己的兄弟(是否有兄弟)。

        通过这种遍历,就将一般树转化为二叉树存储

        i.代码

class CSNode
{
public:int data;//第一个孩子和右兄弟指针CSNode* firstchild,* nextbrother;
};
using CSTree = CSNode*;

        此法可以用来存储森林,每个树都转为二叉树,每个根节点都是平级的,可以看着兄弟结点。

5.树的先根遍历(深度优先遍历)

        先根:先访问根节点,再依次对子树进行先根遍历。

        在孩子兄弟表示法中,对一般树的先根遍历,与其对应的二叉树的先序遍历相同。

        代码中的部分内容会因为选择的存储结构的不同而有差异。

        i.代码

        以下,用孩子兄弟表示法作为存储结构,

class CSNode
{
public:int data;//第一个孩子和右兄弟指针CSNode* firstchild,* nextbrother;
};
using CSTree = CSNode*;//先根遍历
void PreOrder(CSTree p)
{if (p != nullptr){//访问(子树的)根节点visit(p);//如果该节点还有孩子,则去访问孩子if (p->firstchild != nullptr){CSNode* n = p->firstchild;PreOrder(n);}//如果该节点还有兄弟,则再去访问if (p->nextbrother != nullptr){CSNode* m = p->nextbrother;PreOrder(m);}}
}

6.树的后根遍历(深度优先遍历)

        后根:其逻辑与后序遍历类似,但是在孩子兄弟表示法中,出现了不同,一般树的后根遍历,与其对应的二叉树的中序遍历相同,这很反直觉。

        

7.树的层次遍历(广度优先遍历)

        即,逐层遍历,与二叉树的层序遍历逻辑基本相同,使用队列来辅助实现。

        · 队列为空,根节点入队

        · 队列非空,队头出队(并访问),同时队头如果有孩子,则其孩子依次入队。

        依次重复以上两个步骤,直到队列再次为空。

8.森林的先序遍历(中序遍历也是同理的)

        将森林转换为二叉树,再进行先序遍历,就是森林的先序遍历。

9.总结图

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

相关文章:

  • 响应式网站模版seo公司推荐推广平台
  • 建设教育网站seo技术好的培训机构
  • p2p网站开发用什么平台深圳网站建设微信开发
  • 网站生成pc应用如何seo推广
  • 杭州响应式网站长春网站优化团队
  • 南通市建设局网站南宁seo优化公司
  • 天津酒店网站制作化工seo顾问
  • 东莞市网络营销推广怎么样seo建设招商
  • 东莞做网站找微客巴巴网站收录大全
  • 网站建设运营要求企业邮箱注册
  • 深圳工信部网站备案信息查询百度app营销软件
  • 云南做网站哪家便宜在线发外链工具
  • 网站放假通知免费网站建设
  • 如何让别人看到自己做的网站微信小程序开发教程
  • 淘宝网站那个做的app推广方案范例
  • 贵阳网站制作cncolour手机做网页的软件
  • 用群晖做网站服务器长春seo招聘
  • 网站开发工程师 课程大纲网站优化推广培训
  • 网站维护需要网络营销的优缺点
  • 做印刷去哪个网站找工作深圳网络推广外包
  • wordpress主题图片替换班级优化大师使用指南
  • wordpress db host网站优化排名金苹果系统
  • 西安网站建设公司有哪些品牌营销案例分析
  • 英文seo网站建设娃哈哈软文推广
  • 企业网站建设的目的有()网上竞价平台
  • 南阳专业做网站小程序开发教程全集免费
  • 轴承外贸平台哪个网站最好关于网络推广的方法
  • 企业网站一般多少钱seo网站关键词优化报价
  • 企鹅号自媒体平台注册优化大师下载
  • 强网站日常监测及内容建设北京百度关键词优化