数据结构 实验 2

题目一:遍历二叉树

一、实验目的

  1. 熟练掌握指针变量、链表的含义
  2. 掌握二叉树的结构特性,以及二叉链表的存储方式的特点
  3. 掌握用递归的方法处理二叉树的基本算法
  4. 掌握二叉树的四种遍历方式(先序、中序、后序、按层次)

二、实验步骤

  1. 以二叉链表作为存储结构,要求以二叉树的先根序列输入建立二叉树。算法如下:
    void CreatBiTree(BiTree &T)

{

      char ch;

      cin>>ch;

      if(ch= ='#')

      T=NULL;

      else

      {

            T=new BiTNode;

            T->data=ch;

            CreatBiTree(T->lchild);

            CreatBiTree(T->rchild);                    

      }

}
例如,对下图所示的二叉树,则要求依次读入下列字符序列,则可建立相应的二叉链表:AB#D##CE###

  1. 分别给出先序中序(算法如下)、后序遍历二叉树的递归算法在二叉链表上的实现。
    InOrderTraverse (BiTree T)

{
       if(T)

{
            InOrderTraverse(T->lchild);

cout<<T->data;
            InOrderTraverse(T->rchild);
       }
    }

  1. 给出二叉树的按层次遍历的算法。
  2. 求二叉树的高度
  3. 计算二叉树结点总数
  4. 输出叶子结点统计其个数
  5. 如何判断一颗二叉树是否满二叉树

三、实验要求

实验代码:

#include <iostream>
using namespace std;struct BiTNode
{char data;BiTNode *lchild, *rchild;
};void visit(BiTNode *T)
{cout << T->data << " ";
}void CreatBiTree(BiTNode *&T)
{char ch;cin >> ch;if (ch == '#')T = NULL;else {T = new BiTNode;T->data = ch;CreatBiTree(T->lchild);CreatBiTree(T->rchild);}
}void PreOrderTraverse(BiTNode *T)
{if (T){visit(T);PreOrderTraverse(T->lchild);PreOrderTraverse(T->rchild);}
}void InOrderTraverse(BiTNode *T)
{if (T){InOrderTraverse(T->lchild);visit(T);InOrderTraverse(T->rchild);}
}void PostOrderTraverse(BiTNode *T)
{if (T){PostOrderTraverse(T->lchild);PostOrderTraverse(T->rchild);visit(T);}
}void LevelOrderTraverse(BiTNode *T)
{BiTNode *queue[100];int front = 0, rear = 0;if (T){queue[rear++] = T;while (front != rear){T = queue[front++];visit(T);if (T->lchild)queue[rear++] = T->lchild;if (T->rchild)queue[rear++] = T->rchild;}}
}void LeafCount(BiTNode *T, int &count)
{if (!T)return;if (!T->lchild && !T->rchild){visit(T);count++;}LeafCount(T->lchild, count);LeafCount(T->rchild, count);
}int TreeHeight(BiTNode *T)
{if (!T)return 0;int leftHeight = TreeHeight(T->lchild);int rightHeight = TreeHeight(T->rchild);return max(leftHeight, rightHeight) + 1;
}int TreeNodeCount(BiTNode *T)
{if (!T)return 0;return TreeNodeCount(T->lchild) + TreeNodeCount(T->rchild) + 1;
}int main()
{BiTNode *root;CreatBiTree(root);cout << "先序遍历: ";PreOrderTraverse(root);cout << endl;cout << "中序遍历: ";InOrderTraverse(root);cout << endl;cout << "后序遍历: ";PostOrderTraverse(root);cout << endl;cout << "层次遍历: ";LevelOrderTraverse(root);cout << endl;cout << "二叉树高度: " << TreeHeight(root) << endl;cout << "二叉树结点总数: " << TreeNodeCount(root) << endl;cout << "叶子结点: ";int leafCount = 0;LeafCount(root, leafCount);cout << endl;cout << "叶子结点个数: " << leafCount << endl;if(pow(2.0,TreeHeight(root))-1 == TreeNodeCount(root)){cout<<"该二叉树为满二叉树"<<endl;}else{cout<<"该二叉不为满二叉树"<<endl;}return 0;
}

题目二:用二叉树实现高校社团管理

  • 问题描述:在高校中,为了丰富学生的业余生活,在学校的帮助下,会成立许多社团,少则几个,多则几十个。为了有效管理这些社团,要求编写程序实现以下功能:

增加社团或会员;

修改社团或会员相应信息;

查询社团或会员信息;

显示所有社团和会员信息;

  • 问题分析:社团管理部门、社团和社团成员构成了完整的一棵树,如图1和图2所示。因此可以把它作为树的问题来解决。由于树结构比较复杂,不利于求解,先把树转换成二叉树。因此,高校社团管理就转化为对二叉树操作的问题。

在这颗二叉树中,结点类型是不同的,有社团结点,有成员结点。为了便于操作,特设置一个标志域type用于区分结点类型。(type=0表示社团,type=1表示会员)。

信息表

type

name

phone

0

社团管理委员会

23698

0

武术协会

34567

0

桥牌协会

45678

0

足球协会

12345

1

张三

13567

1

李四

13756

1

王五

133456

  • 程序简介
  1. 数据结构的设计

typedef struct info  //定义结点数据类型

{

       int type;        //0为社团,1为社团成员

       char name[20];    //社团名称或成员姓名

       char phone[11];   //联系电话

}DataType;

typedef struct Node    //定义二叉链表数据类型

{

       DataType data;

       struct Node *lchild;

       struct Node *rchild;

}BTNode,*BiTree;

  1. 主程序模块

int main(void)

{

       BiTree r;

       int choice;

       CreatBiTree(r);

       while(1)

       {

              cout<<endl<<"高校社团管理系统"<<endl;

              cout<<"**********主菜单**********"<<endl;

              cout<<"     (1)增加社团或会员"<<endl;

              cout<<"     (2)修改社团或会员信息"<<endl;

              cout<<"     (3)查询社团或会员信息"<<endl;

              cout<<"     (4)显示所有信息"<<endl;

              cout<<"     (0)退出"<<endl;

              cout<<"请选择(1,2,3,4,0):";

              cin>>choice;

              if(choice<0||choice>4)

                     continue;

              switch(choice)

              {           

                     case 1:

                            Insert(r);

                            break;

                     case 2:

                            Update(r);

                            break;

                     case 3:

                            DisplayNode(r);

                            break;

                     case 4:

                            DisplayAll(r);

                            break;

                     case 0:

                            exit(0);

                     default:

                            break;

              }

       }

       system("pause");

       return 0;

}

  1. 各个函数功能

void CreatBiTree(BiTree &r)   //前序遍历法创建二叉树

void DisplayNode(BiTree r)   //根据名称查询并显示社团或会员信息

void Update(BiTree &r) 

//修改社团或会员信息,若要修改的结点不存在,打印“不存在”,否则从键盘输入新的结点信息更新原有结点信息。

void Insert(BiTree &r)         //增加社团或会员

void DisplayAll(BiTree r)       //层次遍历,显示所有信息

  1. 系统界面显示效果

  • 实验要求:
  1. 编写程序,使之能够实现基本的功能。
      1. 前序遍历法创建二叉树
      2. 显示所有信息
      3. 查询信息
      4. 修改信息
      5. 添加信息
  2. 添加功能int NodeCount(BiTree r)统计节点总数

实验代码:

#include <iostream>
using namespace std;typedef struct info
{int type; //0 为社团,1 为社团成员char name[20]; //社团名称或成员姓名char phone[11]; //联系电话
} DataType;typedef struct Node
{DataType data;struct Node *lchild;struct Node *rchild;
} BTNode, *BiTree;void CreatBiTree(BiTree &r)
{DataType data;cin >> data.type >> data.name >> data.phone;if (data.type == -1){r = NULL;}else{r = new BTNode;r->data = data;CreatBiTree(r->lchild);CreatBiTree(r->rchild);}
}void DisplayNode(BiTree r, const DataType &data)
{if (r == NULL){return;}if (strcmp(r->data.name, data.name) == 0){cout << "社团或会员信息为:"<< endl;cout << r->data.type << " " << r->data.name << " " << r->data.phone << endl;}DisplayNode(r->lchild, data);DisplayNode(r->rchild, data);
}void Update(BiTree &r, const DataType &data)
{if (r == NULL){return;}if (strcmp(r->data.name, data.name) == 0){cin >> r->data.type >> r->data.name >> r->data.phone;}Update(r->lchild, data);Update(r->rchild, data);
}void Insert(BiTree &r)
{if (r == NULL){r = new BTNode;cin >> r->data.type >> r->data.name >> r->data.phone;r->lchild = NULL;r->rchild = NULL;}else{int choice;cout << "请选择插入位置(1.左子树 2.右子树):";cin >> choice;if (choice == 1){Insert(r->lchild);}else{Insert(r->rchild);}}
}void DisplayAll(BiTree r)
{if (r == NULL){return;}cout << r->data.type << " " << r->data.name << " " << r->data.phone << endl;DisplayAll(r->lchild);DisplayAll(r->rchild);
}int NodeCount(BiTree r)
{if (r == NULL){return 0;}return NodeCount(r->lchild) + NodeCount(r->rchild) + 1;
}int main(void)
{BiTree r;int choice;CreatBiTree(r);while (1){cout << endl << "高校社团管理系统" << endl;cout << "**********主菜单**********" << endl;cout << " (1)增加社团或会员" << endl;cout << " (2)修改社团或会员信息" << endl;cout << " (3)查询社团或会员信息" << endl;cout << " (4)显示所有信息" << endl;cout << " (5)统计节点总数" << endl;cout << " (0)退出" << endl;cout << "请选择(1,2,3,4,5,0):";cin >> choice;if (choice < 0 || choice > 5)continue;switch (choice){case 1:Insert(r);break;case 2:{DataType data;cin >> data.type >> data.name >> data.phone;Update(r, data);break;}case 3:{DataType data;cin >> data.type >> data.name >> data.phone;DisplayNode(r, data);break;}case 4:DisplayAll(r);break;case 5:cout<<"节点总数为:"<<NodeCount(r)<<endl;break;case 0:exit(0);default:break;}}system("pause");return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1451272.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

java(JVM)

JVM Java的JVM&#xff08;Java虚拟机&#xff09;是运行Java程序的关键部件。它不直接理解或执行Java源代码&#xff0c;而是与Java编译器生成的字节码&#xff08;Bytecode&#xff09;进行交互。下面是对Java JVM更详尽的解释&#xff1a; 1.字节码&#xff1a; 当你使用J…

【elementui源码解析】如何实现自动渲染md文档-第一篇

文章目录 目录 背景 获取源码 代码分析 背景 之前基于vant3的源码开发过二次开发过组件&#xff0c;其中vant实现了将md文档渲染到界面上&#xff0c;有天突发奇想想知道这是如何实现的将md文档渲染到界面上的&#xff0c;因为平时开发中使用elementui占多数&#xff0c;所…

【kaggle量化交易第一名方案】Trading at the Close

2024 1st Place Solution Overview 最终模型(CV/Private LB为5.8117/5.4030)是CatBoost(5.8240/5.4165)、GRU(5.8481/5.4259)和Transformer(5.8619/5.4296)的组合,权重分别为0.5、0.3、0.2,从验证集中搜索得到。这些模型共享相同的300个特征。 此外,在线学习(On…

docker的教程长亭

把我的常用docker写在这里 之前用 vul - hub 靶场经常用 现在docker不知道为什么挂了 开启 docker-compose up -d 关闭 docker-compose down docker ps 只是运行 docker ps -a 所有 包括停止 docker ps -q 只看id docker stop <container_name_or_id> docker 的容器…

Linux Debian12使用podman安装xss-labs靶场环境

一、xss-labs简介 xss-labs靶场是一个专门用于学习和练习跨站脚本攻击&#xff08;XSS&#xff09;技术的在线平台。它提供了一系列的实验场景和演示&#xff0c;帮助安全研究人员、开发人员和安全爱好者深入了解XSS攻击的原理和防御方法。 二、安装podman环境 Linux Debian…

SylixOS下UDP组播测试程序

SylixOS下UDP组播测试 测试效果截图如下: udp组播发送测试程序。 /********************************************************************************************************* ** ** 中国软件开源组织 ** ** …

vite配置unocss

在vue3vitetseslintprettierstylelinthuskylint-stagedcommitlintcommitizencz-git介绍了关于vitevue工程化搭建&#xff0c;现在在这个基础上&#xff0c;我们增加一下unocss unocss官方文档 具体开发中使用遇到的问题可以参考不喜欢原子化CSS得我&#xff0c;还是在新项目中使…

H5单点登录分析介绍(登录状态检验状态透传分析)

文章目录 1、单点登录解决方案1.1、后端保存登录状态1.2、token模式 2、user服务-登录接口2.1、UserController2.2、UserInfoServiceImpl2.3、载荷2.4、响应2.5、Redis Desktop Manager 3、user服务-登录成功获取用户信息回显3.1、UserController3.2、UserInfoServiceImpl3.3、…

【kubernetes】k8s中包管理工具-----Helm 超详细解读

目录 一、Helm 1.1什么是 Helm 1.2Helm 有三个重要的概念 1.2.1Chart 1.2.2Repository&#xff08;仓库&#xff09; 1.2.3Release 1.3Helm3 与 Helm2 的区别 二、Helm 部署 2.1安装 helm 2.2命令补全 2.3使用 helm 安装 Chart 2.3.1添加常用的 chart 仓库 2.3.2…

【springBoot学习篇】springBoot集成mybatis

目录 第一步&#xff1a;新建spring项目的时候&#xff0c;需要勾选mybatis框架和jdbc连接数据库的包 第二步&#xff1a;在resource目录下面的配置文件当中添加以下的内容&#xff1a;配置数据源 第三步&#xff1a;配置实体类 第四步&#xff1a;添加一个对象的增删改查方…

鸿蒙轻内核Kconfig使用笔记

鸿蒙轻内核使用Kconfig进行图形化配置&#xff0c;本文专门讲解下鸿蒙轻内核LiteOS-M和LiteOS-A的图形化配置方法。本文中所涉及的源码&#xff0c;均可以在开源站点 https://gitee.com/openharmony/kernel_liteos_a 、 https://gitee.com/openharmony/kernel_liteos_m 获取。本…

Ubuntu系统设置中文输入法

重新设置超级用户权限(root)密码(非必要) sudo passwd root 需要注意的是Ubuntu的root密码不能少于8个字符 设置成功后输入命令和新的密码即可无需输入sudo启用root命令 su - 更新软件包列表 sudo apt update sudo apt upgrade 安装fcitx5输入法框架 个别情况需要卸载旧的…

EC20通信模块升级失败 Quectel QDLoader 9008

这里写自定义目录标题 usb驱动下载固件和升级软件下载开始升级上述过程升级失败&#xff0c;出现Quectel QDLoader 9008寻找解决方案&#xff0c;事了QPS t不行&#xff0c;最终使用这个Quectel_Customer_FW_Download_Tool软件解决下载链接&#xff1a; 所有下载驱动、固件、软…

【在线OJ】发帖功能前后段代码实现

一、页面布局 二、前端代码 <template><div id"app"><div style"height: 100vh"><div style"display: flex" ><el-input style"width: 95%" v-model"title" placeholder"输入标题"&g…

【Spine学习07】之跑步动作制作思路总结

前几节试着做了待机和走路动画 现在开始尝试做跑步动作 注意跑步动作和走路一样 暂时不需要使用IK约束但是会用到塞贝尔曲线&#xff08;模拟裙子飞起动效&#xff09; 第一步&#xff1a; 先将人物整体斜放置&#xff08;因为人跑步的时候&#xff0c;身体前倾&#xff09; …

『大模型笔记』主成分分析(PCA)解释:简化机器学习中的复杂数据!

主成分分析(PCA)解释:简化机器学习中的复杂数据 文章目录 一. 主成分分析(PCA)解释:简化机器学习中的复杂数据!二. 参考文献一. 主成分分析(PCA)解释:简化机器学习中的复杂数据! 主成分分析(Principal Component Analysis,简称PCA)通过 将大型数据集中的维度减少…

借助ollama实现AI绘画提示词自由,操作简单只需一个节点!

只需要将ollama部署到本地&#xff0c;借助comfyui ollama节点即可给你的Ai绘画提示词插上想象的翅膀。具体看详细步骤&#xff01; 第一步打开ollama官网&#xff1a;https://ollama.com/&#xff0c;并选择models显存太小选择的是llama3\8b参数的instruct-q6_k的这个模型。 运…

blender bpy将顶点颜色转换为UV纹理vertex color to texture

一、关于环境 安装blender的bpy&#xff0c;不需要额外再安装blender软件。在python控制台中直接输入pip install bpy即可。 二、关于代码 本文所给出代码仅为参考&#xff0c;禁止转载和引用&#xff0c;仅供个人学习。 本文所给出的例子是https://download.csdn.net/downl…

手写轮播列表(最新) 轮播图 swiper

el-row版本: <template><div class="container-div" id="app"><div><!-- 头部开始--><div class="top1"><div class="content"><div class="list"><el-row :gutter=&quo…

在ubuntu中恢复误删除的文件

1、安装 TestDisk 在 Ubuntu 上&#xff0c;可以使用以下命令安装 TestDisk&#xff1a; sudo apt-get install testdisk2、查询你删除的文件所在那个分区 #查询分区 df -h #我这里是/dev/sda2 #也可以使用下面命令查看具体哪个分区 lsblk3、查询该分区是什么系统类型 sudo …