DS博客作业05--树

1.本周学习总结

1.思维导图

2.谈谈你对树结构的认识及学习体会

相对于之前的栈和队列,树的学习难度明显. 相较于之前的线性结构, 树更多的需要应用递归思维. 循环结构用多了之后, 对于转变到递归难以适应, 考虑问题的方式也改变了
树表示数据表素之间一对多的关系,可以分为二叉树(完全二叉树、满二叉树、平衡二叉树、排序二叉树),红黑树,哈夫曼树等等,遍历的顺序也有很多种:中序遍历,
先序遍历、后序遍历、层次遍历等等(每一种我们都要掌握),分类较多,应用的范围也很广.

2.PTA实验作业

2.1题目一:6-2 中序输出度为1的结点

2.1.1设计思路(伪代码)

由题目中序输出可知,先左子树,再根,在右子树
If T!=NULL //树不为空
递归遍历左子树
If 右子树==NULL 且左子树!=NULL 或者 左子树==NULL且右子树!=NULL
输出 

2.1.2代码截图

2.1.3提交列表及说明


if的判断条件出错

2.2题目二:7-1 还原二叉树

2.2.1 设计思路

int Height(int num1,int num2,int lenth,int H)
if lenth == 0 
    返回 H-1;
    int len = 0;
    while(1)
	{
        if  Str2[num2+len] == Str1[num1]
		break;
       
           len++;      
    }
     应用递归算法
    int h1 = Height(num1+1,num2,len,H+1);   返回左子树最大高度 
    int h2 = Height(num1+len+1,num2+len+1,lenth-1-len,H+1);  返回右子树最大高度
 
    返回高度

2.2.2代码截图


2.2.3本题PTA提交列表说明

2.3 题目3:7-2 根据后序和中序遍历输出先序遍历 (25 分)

2.3.1 代码思路

void preorder(int a[], int b[], int n)
if n不为0
    后序遍历的最后一个元素为根
    for i=0 to n
        if b[i]=根 then m=i为根在中序遍历中的位置
    输出元素
    递归调用本函数

2.3.2 代码截图


2.3.3 提交列表

3.阅读代码

3.1 题目 计算一棵树的宽度(并输出每一层的宽度)

3.2 解题思路

作者解题思路:
先创建一个队列,用一个标注变量去标注最开始时队尾的位置,然后用一个循环来操作二叉树,循环体内的操作和层序遍历类似,不同的是,在每趟循环结束后都要来判断上一层是否便利完成(用那个标注变量和队首的位置比较)如果便利完成,则刷新最大宽度。

3.3 代码截图


3.4 学习体会

通过此题,加成了对于层次遍历的做法,相对于前中后序遍历来说,层次遍历需要用队列辅助实现,对于代码的操作多了许多

posted @ 2019-05-18 21:06  blame  阅读(231)  评论(0编辑  收藏  举报