数据结构——二叉树PTA习题(未完,有不会的)

简介: 数据结构——二叉树PTA习题(未完,有不会的)

单选题


image.png

image.png

image.png


单选题题解


3、由中序判断左右子树,中序遍历顺序左子树,根节点,右子树,先序遍历的左子树元素在右子树元素之前,后序遍历顺序是的左子树,右子树,根节点


6、“二叉树中的度“是指树中最大的结点度,叶子结点是终端结点,是度为0 的结点。


二叉树的度是指树中所以结点的度数的最大值。二叉树的度小于等于2,因为二叉树的定义要求二叉树中任意结点的度数(结点的分支数)小于等于2 ,并且两个子树有左右之分,顺序不可颠倒。


叶子结点就是度为0的结点,也就是没有子结点的结点叶子。如n0表示度为0的结点数,n1表示度为1的结点,n2表示度为2的结点数。在二叉树中:n0=n2+1;N=n0+n1+n2(N是总结点)。


8 、二叉树定义:二叉树是每个节点最多有两个子树的有序树,通常子树的根被称作“左子树”和“右子树”。”


具有3个结点的二叉树,有2层和3层两种情况


若有2层,则只有一种情况


若有3层,则每层只有1个结点,一共有2*2种情况


函数题


6-1 先序输出叶结点 (30分)


本题要求按照先序遍历的顺序输出给定二叉树的叶结点。


函数接口定义:


void PreorderPrintLeaves( BinTree BT );


其中BinTree结构定义如下:


typedef struct TNode *Position;
typedef Position BinTree;
struct TNode{
    ElementType Data;
    BinTree Left;
    BinTree Right;
};


函数PreorderPrintLeaves应按照先序遍历的顺序输出给定二叉树BT的叶结点,格式为一个空格跟着一个字符。


输出样例(对于图中给出的树):



Leaf nodes are: D E H I


代码


#include <stdio.h>
#include <stdlib.h>
typedef char ElementType;
typedef struct TNode *Position;
typedef Position BinTree;
struct TNode{
    ElementType Data;
    BinTree Left;
    BinTree Right;
};
BinTree CreatBinTree();
void PreorderPrintLeaves( BinTree BT );
int main()
{
    BinTree BT = CreatBinTree();
    printf("Leaf nodes are:");
    PreorderPrintLeaves(BT);
    printf("\n");
    return 0;
}
BinTree CreatBinTree() {
    BinTree Bt = NULL;
    int n;
    ElementType ch;
    scanf("%d",&n);
    for(int i = 0;i < n;i ++) {
        getchar();
        scanf("%c",&ch);
        Bt = Insert(Bt,ch);
    }
    return Bt;
}
/* 你的代码将被嵌在这里 */
if(BT)
{
  if(BT->Left==NULL&&BT->Right==NULL)
        printf(" %c",BT->Data);     //格式为一个空格跟着一个字符。
    PreorderPrintLeaves(BT->Left);
    PreorderPrintLeaves(BT->Right);
}              


编程题


7-1 列出叶结点 (20分)


对于给定的二叉树,本题要求你按从上到下、从左到右的顺序输出其所有叶节点。


输入格式:


首先第一行给出一个正整数 N(≤10),为树中结点总数。树中的结点从 0 到 N−1 编号。随后 N 行,每行给出一个对应结点左右孩子的编号。如果某个孩子不存在,则在对应位置给出 “-”。编号间以 1 个空格分隔。


输出格式:


在一行中按规定顺序输出叶节点的编号。编号间以 1 个空格分隔,行首尾不得有多余空格。


输入样例:


8
1 -
- -
0 -
2 7
- -
- -
5 -
4 6


输出样例:


4 1 5


代码(未完,不大会)


#include<iostream>
#include<stdio.h>
#include<queue>
#include<vector>
#include<algorithm>
using namespace std;
struct Node
{
  int l, r;
}q[10];
int v[10];
queue <int> Q;
vector <int> ans;
// 层序输出
void bfs()
{
  int len = Q.size();
  for (int i = 0; i < len; i++)
  {
    int num = Q.front();
    Q.pop();
    if (q[num].l == -1 && q[num].r == -1) // 左右子树都为空,直接写进去
      ans.push_back(num);
    if (q[num].l != -1)
      Q.push(q[num].l);
    if (q[num].r != -1)
      Q.push(q[num].r);
  }
  if (Q.size())
    bfs();
}
int main()
{
  memset(q, 0, sizeof(q));
  memset(v, 0, sizeof(v));
  int n;
  scanf("%d", &n);
  char a, b;
  for (int i = 0; i < n; i++)
  {
    scanf(" %c %c", &a, &b);
    if (a == '-')
      q[i].l = -1;
    else
    {
      q[i].l = a - '0';
      v[a - '0'] = 1;
    }
    if (b == '-')
      q[i].r = -1;
    else
    {
      q[i].r = b - '0';
      v[b - '0'] = 1;
    }
  }
  int root;
  for (int i = 0; i < n; i++)
  {
    if (v[i] == 0)
    {
      root = i;
      break;
    }
  }
  Q.push(root);
  bfs();
  vector <int>::iterator it;
  for (it = ans.begin(); it != ans.end(); it++)
  {
    if (it != ans.begin())
      printf(" ");
    printf("%d", *it);
  }
  cout << endl;
}
相关文章
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
621 77
|
11月前
|
存储 算法 Java
算法系列之数据结构-二叉树
树是一种重要的非线性数据结构,广泛应用于各种算法和应用中。本文介绍了树的基本概念、常见类型(如二叉树、满二叉树、完全二叉树、平衡二叉树、B树等)及其在Java中的实现。通过递归方法实现了二叉树的前序、中序、后序和层次遍历,并展示了具体的代码示例和运行结果。掌握树结构有助于提高编程能力,优化算法设计。
351 10
 算法系列之数据结构-二叉树
|
存储 C++
【C++数据结构——树】哈夫曼树(头歌实践教学平台习题) 【合集】
【数据结构——树】哈夫曼树(头歌实践教学平台习题)【合集】目录 任务描述 相关知识 测试说明 我的通关代码: 测试结果:任务描述 本关任务:编写一个程序构建哈夫曼树和生成哈夫曼编码。 相关知识 为了完成本关任务,你需要掌握: 1.如何构建哈夫曼树, 2.如何生成哈夫曼编码。 测试说明 平台会对你编写的代码进行测试: 测试输入: 1192677541518462450242195190181174157138124123 (用户分别输入所列单词的频度) 预
485 14
【C++数据结构——树】哈夫曼树(头歌实践教学平台习题) 【合集】
|
存储 人工智能 算法
【C++数据结构——图】最短路径(头歌教学实验平台习题) 【合集】
任务描述 本关任务:编写一个程序,利用Dijkstra算法,实现带权有向图的最短路径。 相关知识 为了完成本关任务,你需要掌握:Dijkst本关任务:编写一个程序,利用Dijkstra算法,实现带权有向图的最短路径。为了完成本关任务,你需要掌握:Dijkstra算法。带权有向图:该图对应的二维数组如下所示:Dijkstra算法:Dijkstra算法是指给定一个带权有向图G与源点v,求从v到G中其他顶点的最短路径。Dijkstra算法的具体步骤如下:(1)初始时,S只包含源点,即S={v},v的距离为0。
192 15
|
Java C++
【C++数据结构——树】二叉树的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现二叉树的基本运算。​ 相关知识 创建二叉树 销毁二叉树 查找结点 求二叉树的高度 输出二叉树 //二叉树节点结构体定义 structTreeNode{ intval; TreeNode*left; TreeNode*right; TreeNode(intx):val(x),left(NULL),right(NULL){} }; 创建二叉树 //创建二叉树函数(简单示例,手动构建) TreeNode*create
404 12
|
C++
【C++数据结构——树】二叉树的性质(头歌实践教学平台习题)【合集】
本文档介绍了如何根据二叉树的括号表示串创建二叉树,并计算其结点个数、叶子结点个数、某结点的层次和二叉树的宽度。主要内容包括: 1. **定义二叉树节点结构体**:定义了包含节点值、左子节点指针和右子节点指针的结构体。 2. **实现构建二叉树的函数**:通过解析括号表示串,递归地构建二叉树的各个节点及其子树。 3. **使用示例**:展示了如何调用 `buildTree` 函数构建二叉树并进行简单验证。 4. **计算二叉树属性**: - 计算二叉树节点个数。 - 计算二叉树叶子节点个数。 - 计算某节点的层次。 - 计算二叉树的宽度。 最后,提供了测试说明及通关代
219 10
|
算法 C++
【C++数据结构——图】最小生成树(头歌实践教学平台习题) 【合集】
【数据结构——图】最小生成树(头歌实践教学平台习题)目录 任务描述 相关知识 测试说明 我的通关代码: 测试结果:【合集】任务描述 本关任务:编写一个程序求图的最小生成树。相关知识 为了完成本关任务,你需要掌握:1.建立邻接矩阵,2.Prim算法。建立邻接矩阵 上述带权无向图对应的二维数组,根据它建立邻接矩阵,如图1建立下列邻接矩阵。注意:INF表示无穷大,表示整数:32767 intA[MAXV][MAXV];Prim算法 普里姆(Prim)算法是一种构造性算法,从候选边中挑
190 10
|
存储 算法 C++
【C++数据结构——图】图的邻接矩阵和邻接表的存储(头歌实践教学平台习题)【合集】
本任务要求编写程序实现图的邻接矩阵和邻接表的存储。需掌握带权有向图、图的邻接矩阵及邻接表的概念。邻接矩阵用于表示顶点间的连接关系,邻接表则通过链表结构存储图信息。测试输入为图的顶点数、边数及邻接矩阵,预期输出为Prim算法求解结果。通关代码提供了完整的C++实现,包括输入、构建和打印邻接矩阵与邻接表的功能。
618 10
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
349 59
|
8月前
|
编译器 C语言 C++
栈区的非法访问导致的死循环(x64)
这段内容主要分析了一段C语言代码在VS2022中形成死循环的原因,涉及栈区内存布局和数组越界问题。代码中`arr[15]`越界访问,修改了变量`i`的值,导致`for`循环条件始终为真,形成死循环。原因是VS2022栈区从低地址到高地址分配内存,`arr`数组与`i`相邻,`arr[15]`恰好覆盖`i`的地址。而在VS2019中,栈区先分配高地址再分配低地址,因此相同代码表现不同。这说明编译器对栈区内存分配顺序的实现差异会导致程序行为不一致,需避免数组越界以确保代码健壮性。
175 0
栈区的非法访问导致的死循环(x64)