Day14打卡! 时长:1.5h
今日感想:今天开启二叉树篇章!主要学习了递归法的遍历,之前学的有一点“浮于表面”,要注重学习基本逻辑,尽量把问题的根本理解透彻。
二叉树重点理论基础
二叉树主要形式:满二叉树(只有度为0的结点和度为2的结点,并且度为0的结点在同一层上,深度为k,有2^k-1个节点的二叉树)和完全二叉树(除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第 h 层,则该层包含 1~ 2^(h-1) 个节点。)
优先级队列其实是一个堆,堆就是一棵完全二叉树,同时保证父子节点的顺序关系。
二叉搜索树:一个有序树,
- 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
- 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
- 它的左、右子树也分别为二叉排序树
平衡二叉搜索树(AVL):是一棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树。
二叉树的存储方式:链式存储(指针)或顺序存储(数组