树(定义、存储结构、遍历二叉树)

树是n(n>=0)个结点的有限集,n=0时称为空树,在任意一颗非空树中:

  • 有且只有一个特定的称为(Root)的结点
  • 当n > 1时,其余结点可分为m(m>0)个互不相交有限集T1,T2...Tm,其中每一个集合本身又是一棵树,并且称为根的子树(SubTree)
  1. 结点拥有的子树称为结点的(Degree),度为0的结点称为叶结点(Leaf)或终端结点,度不为0的结点称为分支结点非终端结点,除根节点之外,分支结点也称为内部结点树的度是树内各结点的度的最大值
  2. 结点的子树的根称为该结点的孩子(Child),该结点称为孩子的双亲(Parent),同一个双亲的孩子之间互称兄弟(Sibling),结点的祖先是从根到该结点所经分支上的所有结点,以某结点为根的子树中的任一结点都称为该结点的子孙
  3. 结点的层次:根为第一层,根的孩子为第二层,双亲在同一层的结点互为堂兄弟,树中结点的最大层次称为树的深度(Depth)或高度
  4. 如果将树中结点的各子树看成从左至右是有顺序的,不能互换的 ,则该树称为有序树,否则称为无序树
  5. 森林是m(m>=0)棵互不相交的树的集合

树的存储结构

简单的顺序存储结构是不能满足树的实现要求的,但结合链式存储结构可以满足

双亲表示法

除了根结点,每个结点一定且仅有一个双亲

  1. 双亲表示法结点定义:在每个结点中附设一个指示器指示其双亲结点在数组中的位置,即一个数据域、一个指针域(存放双亲下标)
  2. 可以灵活扩展此结构,把指针域扩展为长子域、右兄弟域等
  3. 一个存储结构设计的是否合理,取决于基于该存储结构的运算是否合适、方便、时间复杂度好坏等

孩子表示法

每个结点有多个指针域,其中每个指针指向一棵子树的根结点,这称为多重链表表示法,有两种方案:

  • 指针域的个数就等于树的度;对于树中各结点的度相差很大时会浪费空间
  • 是专门取一个位置(度域)来存储结点指针域的个数;各结点的链表结构不同,损耗运算时间

结合该两种方案做到既可以减少空指针的浪费又能使结点结构相同,即孩子表示法,具体为:

  • 把每个结点的孩子结点排列起来,以单链表做存储结构,则n个结点有n个孩子链表,叶子节点为空表
  • n个头指针又组成一个线性表,采用顺序存储结构,存放进一个一维数组中

如此一来,要查找某个结点的某个孩子或兄弟,只需要查找这个结点的孩子单链表即可

如果还想知道某个结点的双亲是谁,可以结合双亲表示法,形成双亲孩子表示法

孩子兄弟表示法

  1. 任何一棵树,它的结点的第一个孩子如果存在,就是唯一的,它的右兄弟如果存在也是唯一的。因此设置两个指针,分别指向该结点的第一个孩子和此结点的右兄弟
  2. 孩子兄弟表示法结构定义:数据域、两个指针域(指向该结点的第一个孩子结点、指向右兄弟结点)

二叉树

由n个结点组成的有限集合,该集合或为空集(空二叉树),或由一个根结点和两棵互不相交、分别称为根结点的左子树右子树的二叉树组成

特点:

  • 每个结点最多有两棵子树(0~2棵)
  • 左子树和右子树的次序不能变
  • 只有一棵子树时也要区分左右子树

二叉树的五种基本形态:空二叉树、只有根结点、只有左子树、只有右子树、有左右子树

特殊二叉树:

  • 斜树:每一层都只有一个结点,结点的个数与二叉树的深度相同;分左斜树右斜树
  • 满二叉树:所有叶子都在最底层;分支结点的度一定是2;与同深度的二叉树比,满二叉树的结点和叶子数最多
  • 完全二叉树:按层序编号,如果编号没出现空档(存在的结点位置和同条件的满二叉树的位置相同)则是;叶结点只能在最后两层,与同深度的二叉树比,完全二叉树的深度最小

二叉树的性质

  1. 性质1:在二叉树的第i层上至多有2^(i-1)个结点(i>=1)
  2. 性质2:深度为k的二叉树至多有(2^k)-1个结点 (k>=1)
  3. 性质3:叶结点数=度为2的结点数+1(通过推导总结点数和分支线总数得出)
  4. 性质4:具有n个结点的完全二叉树的深度为[log2n]+1(性质2的倒推)
  5. 性质5:对一棵有n个结点的完全二叉树的结点按层编号,对任一结点i有
    • 若i=1,则i是根结点,无双亲;若i>1,则双亲是结点i/2
    • 若2i>n,则结点i无左孩子(结点i为叶子结点);否则其左孩子是结点2i
    • 若2i+1>n,则结点i无右孩子;否则其右孩子是结点2i+1

二叉树的存储结构

顺序存储结构:用一维数组存储二叉树中结点,对一般的二叉树不能反应逻辑关系;一般用于完全二叉树
二叉链表:由结点数据(数据域)、左右孩子指针(两个指针域)定义的链表;若再加一个指向双亲的指针域就称为三叉链表

遍历二叉树

指从根结点出发,按照某种次序依次访问二叉树中所有结点,使得每个结点被访问一次且仅被访问一次

前序遍历算法:

先前序遍历左子树,再前序遍历右子树

/* 用C实现二叉树的前序遍历递归算法*/

void PreOrder(BiTree T)
{
    if (T == NULL)
        return;
    printf("%c", T->data);   /*对结点的操作*/
    PreOrder(T->lchild)
    PreOrder(T->rchild)
}

中序遍历算法:

先中序遍历根结点的左子树,然后访问根结点,最后中序遍历右子树
与前序遍历相比相当于把调用左孩子的递归函数提前了
遍历到左孩子为NULL的结点时才返回对结点操作,然后再对该结点的右子树做同样遍历

/* 用C实现二叉树的中遍历递归算法*/

void InOrder(BiTree T)
{
    if (T == NULL)
        return;
    InOrder(T->lchild)    /*提前*/
    printf("%c", T->data);   /*对结点的操作*/
    InOrder(T->rchild)
}

后序遍历算法:

从左到右的顺序先遍历叶子再遍历结点的方式遍历访问左右子树

/* 用C实现二叉树的后遍历递归算法*/

void PostOrder(BiTree T)
{
    if (T == NULL)
        return;
    PostOrder(T->lchild)   /*先左*/
    PostOrder(T->rchild)  /*再右*/
    printf("%c", T->data);   /*对结点的操作*/
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容

  • 四、树与二叉树 1. 二叉树的顺序存储结构 二叉树的顺序存储就是用数组存储二叉树。二叉树的每个结点在顺序存储中都有...
    MinoyJet阅读 1,520评论 0 7
  • 1.树(Tree): 树是 n(n>=0) 个结点的有限集。当 n=0 时称为空树。在任意一颗非空树中:有且仅有一...
    ql2012jz阅读 1,001评论 0 3
  • 1.树的定义 树是n(n>=0)个结点的有限集.n=0时称为空树.在任意一颗非空树种:(1)有且仅有一个特定的称为...
    e40c669177be阅读 2,811评论 1 14
  • 数据结构和算法--二叉树的实现 几种二叉树 1、二叉树 和普通的树相比,二叉树有如下特点: 每个结点最多只有两棵子...
    sunhaiyu阅读 6,443评论 0 14
  • 师姐问什么是“严谨”,我词穷了,第一次发现自己是这样词穷根本不知道该如何去解释这个名词。当小师妹把这个词解释...
    喵是只猫阅读 190评论 0 0