前言
练习
-
- A
- G、H、I、L、M、K
-
以节点B为例
- A
- D、E
- C
- 1
- 3
-
4
-
有N个节点,每个节点有两个指针,总共 2 N 2N 2N个。其中除了根节点每个节点都有一个从其父节点指向自己的指针 N − 1 N-1 N−1,那么剩余的 2 N − ( N − 1 ) = N + 1 2N-(N-1)=N+1 2N−(N−1)=N+1个 N U L L NULL NULL。
-
归纳法,当H=0时,结论成立。假设H为1、2、3、……k时结论成立。那么当H为k+1时,可以看作高度为k的左右子树和一个根,左右子树的节点都为 2 k + 1 − 1 2^{k+1}-1 2k+1−1,它们的节点和为 2 ∗ 2 k + 1 − 2 2*2^{k+1}-2 2∗2k+1−2,即 2 ( k + 1 ) + 1 − 2 2^{(k+1)+1}-2 2(k+1)+1−2。再加上根节点,即 2 ( k + 1 ) + 1 − 1 2^{(k+1)+1}-1 2(k+1)+1−1,故结论成立。
-
假设二叉树有N个节点,其中F个满节点,L个叶子,H个单节点(只有一个儿子),则 N = F + L + H N=F+L+H N=F+L+H。因为该树有N个节点,那么一定有 N − 1 N-1 N−1个儿子,其中F个满节点有 2 F 2F 2F个儿子,H个单节点有 H H H个儿子,则 N − 1 = 2 F + H N-1=2F+H N−1=2F+H。后式减前式得到, L − F = 1 L-F=1 L−F=1,故成立。
-
归纳法,空树时和为0,当树有唯一根节点时,和为1。假设树有 k k k个节点时公式成立。那么当树有 k + 1 k+1 k+1个节点时,我们可以把树看作拥有 i i i个节点的左树、 k − i k-i k−i个节点的右树和根结点的组合。分析左树,因为 i i i小于 k k k,故 Σ i = 1 M 2 − d i ≤ 1 \Sigma_{i=1}^{M}2^{-d_i}\leq1 Σi=1M2−di≤1成立。因为根节点,所以左树所有树叶的实际深度都加一,即 2 − ( d i + 1 ) 2^{-(d_i+1)} 2−(di+1),亦即 1 2 × 2 − d i \frac12\times2^{-d_i} 21×2−di。所以,左树的各树叶深度的和 ≤ 1 2 \leq\frac12 ≤21。右树同理。那么它们合起来 ≤ 1 \leq1 ≤1,亦即当树有 k + 1 k+1 k+1个节点时,推论成立,所以公式成立。
当树中只有拥有0个儿子或2个儿子的节点时,等号成立。因为如果拥有一个儿子的节点时等号成立,那么给该节点插入另一个儿子时,和就会大于1。 -
- 前缀表达式 − ∗ ∗ a b + c d e -**ab+cde −∗∗ab+cde
- 中缀表达式 ( ( a ∗ b ) ∗ ( c + d ) ) − e ((a*b)*(c+d))-e ((a∗b)∗(c+d))−e
- 后缀表达式 a b ∗ c d + ∗ e − ab*cd+*e- ab∗cd+∗e−
- 二叉查找树
- 怀疑题目是要求使用游标实现法实现二叉查找树。
-
- 维护一个数组Array[M],如果index在树上,那么置Array[index-1]为true。然后重复生成1到M之间的随机数,直到其Array[index-1]为false。如果树中已存在N个元素,那么数组中应该有M-N个元素没有在树上,那么找到false的概率为 M − N M \frac{M-N}{M} MM−N。所以每次期望的运行时间是 M M − N {M} \over {M-N} M−NM = = = α α − 1 {α}\over{α-1} α−1α。
- 同理,重复生成1到M之间的随机数,直到其Array[index-1]为true。如果树中已存在N个元素,那么数组中应该有N个元素为true,找到其的概率为 N M {N}\over{M} MN,即 N α N {N}\over{\alpha N} αNN = = = 1 α 1\over{\alpha} α1。所以每次期望的运行时间是 α \alpha α。
- 一对先插入后删除的期望时间是 α α − 1 {α}\over{α-1} α−1α + + + α \alpha α,即 α + 1 + {\alpha +1}+ α+1+ 1 α − 1 \frac{1}{\alpha -1} α−11,于是当 α \alpha α为2时,最小。
- 三种实现
- 略
-
- S ( H ) = S ( H − 1 ) + S ( H − 2 ) + 1 S(H)=S(H-1)+S(H-2)+1 S(H)=S(H−1)+S(H−2)+1, S ( 0 ) = 1 S(0)=1 S(0)=1, S ( 1 ) = 2 S(1)=2 S(1)=2。
- 最少个数是2583
- 所谓完全平衡,很容易得到当 1 ≤ k ≤ 3 1\leq k\leq 3 1≤k≤3时,推论是成立的。假设 k = n k=n k=n时推论也成立。这时候将1,2,… 2 n − 1 2^n-1 2n−1插入树中,恰好第i层有 2 i 2^i 2i个节点(根节点在第0层,i=0,1,2……n-1)。当 k = n + 1 k=n+1 k=n+1时,插入的关键字序列是1,2,……, 2 n − 1 2^n-1 2n−1, 2 n 2^n 2n,…… 2 n + 1 − 1 2^{n+1}-1 2n+1−1。总共增加的节点数为 ( 2 n + 1 − 1 ) (2^{n+1}-1) (2n+1−1) − - − ( 2 n − 1 ) (2^n-1) (2n−1)= 2 n 2^n 2n,那么在AVL树新增的第n层,恰好有 2 n 2^n 2n个节点,根据二叉树的性质,节点数达到该层最多节点个数,则满足完全平衡的要求,因此推论成立。
- 见仓库
- 见仓库,这个Avl树非递归插入的实现想到哪里写到哪里,写得有点乱,有时间再来修改。
- 见仓库