数据结构 实验 2

news2025/7/7 7:23:55

题目一:遍历二叉树

一、实验目的

  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.coloradmin.cn/o/1822279.html

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

相关文章

Unity资源 之 最受欢迎的三消游戏开发包 - Bubble Shooter Kit 【免费领取】

三消游戏开发包 - Bubble Shooter Kit 免费领取 前言资源包内容领取兑换码 前言 如果你是一名 Unity 游戏开发者&#xff0c;并且正在寻找一种快速、简单的方式来创建自己的三消游戏&#xff0c;那么 Bubble Shooter Kit 就是你所需要的。 资源包内容 Bubble Shooter Kit 是…

typora+Picgo使用Lsky pro搭建本地服务图床

typoraPicgo使用Lsky pro搭建本地服务图床 Picgo下载lankong插件lankong插件安装Auth token获取 Picgo测试typora测试问题说明 Picgo下载 Picgo下载&#xff1a;https://github.com/Molunerfinn/PicGo/releases&#xff0c;注意&#xff1a;请直接使用尝鲜版&#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…

2024【大模型】国内市场如何?程序员该何时入局?

1.市场形势 根据最新的市场研究报告&#xff0c;2023年中国的大模型市场呈现出显著的发展趋势和广阔的前景。以下是关于中国大模型市场的几个关键点&#xff1a; 市场规模和增长&#xff1a;2023年&#xff0c;中国AI大模型行业的市场规模达到了147亿元人民币&#xff0c;预计…

stable-diffusion 3 体验部署流程(ComfyUI)

环境准备 下载及简介 git clone https://huggingface.co/stabilityai/stable-diffusion-3-medium SD3 checkpoints&#xff1a; sd3_medium_incl_clips.safetensors (5.5GB)sd3_medium_incl_clips_t5xxlfp8.safetensors (10.1GB)sd3_medium.safetensors (4.3GB) 前两个可以…

RK3568笔记三十二:PaddleSeg训练部署

一、环境 1、Autodl配置 PyTorch 1.7.0Python 3.8(ubuntu18.04)Cuda 11.02、所需环境需求 - OS: 64-bit - Python 3(3.6/3.7/3.8/3.9/3.10)&#xff0c;64-bit version - pip/pip3(9.0.1)&#xff0c;64-bit version - CUDA > 10.2 - cuDNN > 7.6 - PaddlePaddle (the…

qmt量化交易策略小白学习笔记第28期【qmt编程之获取财务数据列表--十大股东和股东数】

qmt编程之获取财务数据 qmt更加详细的教程方法&#xff0c;会持续慢慢梳理。 也可找寻博主的历史文章&#xff0c;搜索关键词查看解决方案 &#xff01; 感谢关注&#xff0c;咨询免费开通量化回测与获取实盘权限&#xff0c;欢迎和博主联系&#xff01; 十大股东/十大流通…

数据结构-稀疏数组

稀疏数组是一种特殊的数据结构&#xff0c;主要用于存储那些大部分元素为零或者未使用的大型数组。以下是关于稀疏数组的详细知识点&#xff0c;按照分点表示和归纳的方式整理&#xff1a; 一、定义 稀疏数组是指那些大部分内容值为空&#xff08;通常为0&#xff09;的数组。…

【Spring6】13-19章 JdbcTemplate+代理模式+AOP+Spring事务+Spring集成MyBatis

十三、JdbcTemplate JdbcTemplate是Spring提供的一个JDBC模板类&#xff0c;是对JDBC的封装&#xff0c;简化JDBC代码。 当然&#xff0c;你也可以不用&#xff0c;可以让Spring集成其它的ORM框架&#xff0c;例如&#xff1a;MyBatis、Hibernate等。 接下来我们简单来学习一下…

【网络编程】TCP原理

TCP套接字中的I/O缓冲 write函数调用后并非立即传输数据&#xff0c;read函数调用后也非马上接收数据。write函数调用瞬间&#xff0c;数据将移至输出缓冲&#xff1b;read函数调用瞬间&#xff0c;从缓冲读取数据。 这些IO缓冲特性可整理如下。 口IO缓冲在每个TCP套接字中单…

人工智能发展历程和工具搭建学习

目录 人工智能的三次浪潮 开发环境介绍 Anaconda Anaconda的下载和安装 下载说明 安装指导 模块介绍 使用Anaconda Navigator Home界面介绍 Environment界面介绍 使用Jupter Notebook 打开Jupter Notebook 配置默认目录 新建文件 两种输入模式 Conda 虚拟环境 添…

C#开发-集合使用和技巧(一)常用集合和方法介绍

C#开发-集合使用和技巧 &#xff08;一&#xff09;常用集合和方法介绍常用集合和方法介绍 C#开发-集合使用和技巧1. 集合基础集合介绍集合跟数组对比 2.我们常用的集合类型列表List<T>键值对集合Dictionary<TKey,TValue>队列Queue<T>其他一些集合类型堆栈St…

04-让LLM理解知识 -Prompt

1 Prompt Prompt 可理解为用于指导AI模型生成特定类型、主题或格式内容的文本。在NLP中&#xff0c;Prompt 通常由一个问题或任务描述组成&#xff0c;例如“给我写一篇有关RAG的文章”&#xff0c;这句话就是Prompt。 Prompt赋予了LLM小样本甚至零样本学习的能力。 大模型的…

07 SpringBoot 配置绑定

所谓“配置绑定”就是把配置文件中的值与 JavaBean 中对应的属性进行绑定。通常&#xff0c;我们会把一些配置信息&#xff08;例如&#xff0c;数据库配置&#xff09;放在配置文件中&#xff0c;然后通过 Java 代码去读取该配置文件&#xff0c;并且把配置文件中指定的配置封…

TF-IDF算法:从文本中发现价值的黄金法则

TF-IDF算法 一、简介二、TF-IDF算法原理2.1 词频&#xff08;TF&#xff09;2.2 逆文档频率&#xff08;IDF&#xff09;2.3 TF-IDF的计算 三、TF-IDF算法应用3.1 搜索引擎3.2 文本分类3.3 信息提取3.4 文本摘要 四、TF-IDF算法的改进4.1、TF-IDF算法的改进4.1.1. 基于词的权重…

DC12V升压24V/5A电流 布控球产品应用 升压恒压SL4010耐压40V芯片

随着科技的不断发展&#xff0c;布控球作为一种高效、精准的安全监控设备&#xff0c;被广泛应用于公安、消防、交通等多个领域。然而&#xff0c;布控球在工作过程中需要稳定的电源供应&#xff0c;以保证其正常运行和长期稳定性。因此&#xff0c;一款性能优良的升压恒压芯片…

百度地图3.0截图,下载(解决图形下载偏移的问题)

百度地图应用3.0开发的页面&#xff0c;需要截图并下载的功能。前端采用html2canvas生成base64图片 由于百度地图绘制多边形是svg&#xff0c;而html2canvas不支持生成。不绘制线的截图是正常的&#xff0c;绘制了线条就会出现偏移。以下是对比&#xff0c;上一张是正常的&…

深入解析B树:数据结构、存储结构与算法优势

一、引言 在计算机科学中&#xff0c;数据结构和算法是核心内容。它们的选择和应用直接影响程序的效率和性能。B树&#xff08;B-Tree&#xff09;作为一种自平衡的多叉树数据结构&#xff0c;广泛应用于数据库和文件系统中。本文将详细介绍B树的数据结构模型、存储结构&#…

ssm创意商城-计算机毕业设计源码03663

摘要 科技进步的飞速发展引起人们日常生活的巨大变化&#xff0c;电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用。信息时代的到来已成为不可阻挡的时尚潮流&#xff0c;人类发展的历史正进入一个新时代。在现实运用中&#xff0c;应用软件的工作规…

JavaScript快速入门系列-2(JavaScript语言基础)

第二章&#xff1a;JavaScript语言基础 2.1 变量声明&#xff1a;let, const, var2.1.1 变量是什么&#xff1f;2.1.2 var2.1.3 let与const2.1.4 选择哪个关键字&#xff1f; 2.2 数据类型2.2.1 基本数据类型2.2.2 复杂数据类型2.2.3 示例与类型检测 2.3 运算符2.3.1 算术运算符…