数据结构与算法分析--c语言描述(原书第二版)练习自答(第四章)(1-20)

目录

前言

  • 章节内部分伪代码使用shell脚本实现1
  • 所有代码都在gitee
  • 每章单独一个目录2,目录内正文的某些小节也有代码实现3
  • #include的本地文件有可能并不在当前目录下,编译失败时请检查。

练习

    1. A
    2. G、H、I、L、M、K
  1. 以节点B为例

    1. A
    2. D、E
    3. C
    4. 1
    5. 3
  2.  4

  3. 有N个节点,每个节点有两个指针,总共 2 N 2N 2N个。其中除了根节点每个节点都有一个从其父节点指向自己的指针 N − 1 N-1 N1,那么剩余的 2 N − ( N − 1 ) = N + 1 2N-(N-1)=N+1 2NN1=N+1 N U L L NULL NULL

  4. 归纳法,当H=0时,结论成立。假设H为1、2、3、……k时结论成立。那么当H为k+1时,可以看作高度为k的左右子树和一个根,左右子树的节点都为 2 k + 1 − 1 2^{k+1}-1 2k+11,它们的节点和为 2 ∗ 2 k + 1 − 2 2*2^{k+1}-2 22k+12,即 2 ( k + 1 ) + 1 − 2 2^{(k+1)+1}-2 2(k+1)+12。再加上根节点,即 2 ( k + 1 ) + 1 − 1 2^{(k+1)+1}-1 2(k+1)+11,故结论成立。

  5. 假设二叉树有N个节点,其中F个满节点,L个叶子,H个单节点(只有一个儿子),则 N = F + L + H N=F+L+H N=F+L+H。因为该树有N个节点,那么一定有 N − 1 N-1 N1个儿子,其中F个满节点有 2 F 2F 2F个儿子,H个单节点有 H H H个儿子,则 N − 1 = 2 F + H N-1=2F+H N1=2F+H。后式减前式得到, L − F = 1 L-F=1 LF=1,故成立。

  6. 归纳法,空树时和为0,当树有唯一根节点时,和为1。假设树有 k k k个节点时公式成立。那么当树有 k + 1 k+1 k+1个节点时,我们可以把树看作拥有 i i i个节点的左树、 k − i k-i ki个节点的右树和根结点的组合。分析左树,因为 i i i小于 k k k,故 Σ i = 1 M 2 − d i ≤ 1 \Sigma_{i=1}^{M}2^{-d_i}\leq1 Σi=1M2di1成立。因为根节点,所以左树所有树叶的实际深度都加一,即 2 − ( d i + 1 ) 2^{-(d_i+1)} 2(di+1),亦即 1 2 × 2 − d i \frac12\times2^{-d_i} 21×2di。所以,左树的各树叶深度的和 ≤ 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 ((ab)(c+d))e
    • 后缀表达式 a b ∗ c d + ∗ e − ab*cd+*e- abcd+e
1
2
3
4
5
6
7
9
1
2
4
5
6
7
9
  1. 二叉查找树
  2. 怀疑题目是要求使用游标实现法实现二叉查找树
    • 维护一个数组Array[M],如果index在树上,那么置Array[index-1]为true。然后重复生成1到M之间的随机数,直到其Array[index-1]为false。如果树中已存在N个元素,那么数组中应该有M-N个元素没有在树上,那么找到false的概率为 M − N M \frac{M-N}{M} MMN。所以每次期望的运行时间是 M M − N {M} \over {M-N} MNM = = = α α − 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时,最小。
  3. 三种实现
    • S ( H ) = S ( H − 1 ) + S ( H − 2 ) + 1 S(H)=S(H-1)+S(H-2)+1 S(H)=S(H1)+S(H2)+1 S ( 0 ) = 1 S(0)=1 S(0)=1 S ( 1 ) = 2 S(1)=2 S(1)=2
    • 最少个数是2583
1
2
3
4
5
6
7
9

测试见test.c

  1. 所谓完全平衡,很容易得到当 1 ≤ k ≤ 3 1\leq k\leq 3 1k3时,推论是成立的。假设 k = n k=n k=n时推论也成立。这时候将1,2,… 2 n − 1 2^n-1 2n1插入树中,恰好第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 2n1 2 n 2^n 2n,…… 2 n + 1 − 1 2^{n+1}-1 2n+11。总共增加的节点数为 ( 2 n + 1 − 1 ) (2^{n+1}-1) (2n+11) − - ( 2 n − 1 ) (2^n-1) (2n1)= 2 n 2^n 2n,那么在AVL树新增的第n层,恰好有 2 n 2^n 2n个节点,根据二叉树的性质,节点数达到该层最多节点个数,则满足完全平衡的要求,因此推论成立。
  2. 见仓库
  3. 见仓库,这个Avl树非递归插入的实现想到哪里写到哪里,写得有点乱,有时间再来修改。
  4. 见仓库

  1. 因为更方便。 ↩︎

  2. 使用chapter标记。 ↩︎

  3. 每个小节的目录名为section。 ↩︎

  • 1
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值