数据结构 实验 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;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux C语言:字符串处理函数

一、字符串函数 1、C库中实现了很多字符串处理函数 #include <string.h> ① 求字符串长度的函数strlen② 字符串拷贝函数strcpy③ 字符串连接函数strcat④ 字符串比较函数strcmp 2、字符串长度函数strlen 格式&#xff1a;strlen(字符数组)功能&#xff1a;计算字符串…

Spring AI 接入OpenAI实现文字生成图片功能

Spring AI 框架集成的图片大模型 2022年出现的三款文生图的现象级产品&#xff0c;DALL-E、Stable Diffusion、Midjourney。 OpenAI dall-e-3dall-e-2 Auzre OpenAI dall-e-3dall-e-2 Stability stable-diffusion-v1-6 ZhiPuAI cogview-3 OpenAI 与 Auzer OpenAI 使用的图片…

接口自动化测试工程化——了解接口测试

什么是接口测试 接口测试也是一种功能测试 我理解的接口测试&#xff0c;其实也是一种功能测试&#xff0c;只是平时大家说的功能测试更多代指 UI 层面的功能测试&#xff0c;而接口测试更偏向于服务端层面的功能测试。 接口测试的目的 测试左移&#xff0c;尽早介入测试&a…

6.归并+快排

5. 归并排序 核心思想 将无序数组从中间分为左右两个部分&#xff0c;分别给左右两个部分排序&#xff0c;排序以后把两个有序区间进行合并 把数组从中间分为左右两部分分别对前后两部分进行排序将排好序的两部分合并 包含两个部分&#xff1a;拆解阶段和合并阶段 归并排序…

跨平台看抖音、哔哩哔哩、虎牙、斗鱼啦,一个app即可完成

一、简介 1、一款免费、开源、无广告、跨平台的,可以观看抖音、哔哩哔哩、虎牙、斗鱼等平台的直播内容的软件。它简单好用,支持 Windows、MacOS、Linux、Android、iOS 等平台。 二、下载 1、文末有下载链接,apk手机可直接安装,不明白可以私聊我哈(麻烦咚咚咚,动动小手给个…

详解QFileSystemModel的使用

在Qt应用程序开发中&#xff0c;QFileSystemModel是一个强大的类&#xff0c;用于展示和操作文件系统的信息。它基于标准的QAbstractItemModel&#xff0c;提供了浏览本地文件系统目录树的能力&#xff0c;并且能够自动更新以反映文件系统的变化。本文将详细讲解QFileSystemMod…

MongoDB——写入耗时

mongodb写入10万条数据的耗时差不多是1s import time import pymongo from pymongo import MongoClient# 连接到MongoDB client MongoClient(mongodb://localhost:27017/) db client[test_db] collection db[test_collection]# 生成10万条数据 documents [{"name&quo…

ThinkPHP内核在线客服系统源码多商户版 对接适用场景(PC+WAP+公众号)

源码介绍 大部分站长都了解美洽系统&#xff0c;就跟这种类似的&#xff0c;可以实现一行代码接入客服&#xff0c;非常舒服&#xff0c;支持无限客服&#xff0c;无限坐席! 私有化源码部署&#xff0c;数据可控&#xff0c;稳定可靠。可自定义版权、logo。支持网页、微信公众…

CPN tools学习——可执行的 PN

目录 1添加令牌 2.转换防护Guard 1添加令牌 左侧新建颜色集和变量的声明定义&#xff1a; 为库所分配颜色集&#xff1a;左键tab键 P1处&#xff1a;添加多重集合&#xff0c;表示添加了两个令牌&#xff0c;第一个令牌值为A&#xff0c;第二个为B。 P2处&#xff1a;表示…

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 的容器…

辣椒属2个T2T基因组-文献精读23

Two telomere-to-telomere gapless genomes reveal insights into Capsicum evolution and capsaicinoid biosynthesis 两个端粒到端粒无缝基因组揭示了辣椒进化和辣椒素生物合成的相关见解 摘要 辣椒&#xff08;Capsicum&#xff09;因其果实中含有辣椒素而闻名&#xff0c…

zabbix自定义监控mysql状态和延迟

zabbix自定义监控mysql状态和延迟 文章目录 zabbix自定义监控mysql状态和延迟zabbix自定义监控mysql状态配置主从配置自定义监控添加监控项添加触发器模拟测试异常 zabbix自定义监控mysql延迟配置自定义监控添加监控项添加触发器测试 zabbix自定义监控mysql状态 配置主从 1.安…

【区间合并 差分 栈】3169. 无需开会的工作日

本文涉及知识点 区间合并 差分数组&#xff08;大约2024年7月1号发) LeetCode3169. 无需开会的工作日 给你一个正整数 days&#xff0c;表示员工可工作的总天数&#xff08;从第 1 天开始&#xff09;。另给你一个二维数组 meetings&#xff0c;长度为 n&#xff0c;其中 me…

蓝牙模块的安全性与隐私保护

蓝牙模块作为现代无线通信的重要组成部分&#xff0c;在智能家居、可穿戴设备、健康监测等多个领域得到了广泛应用。然而&#xff0c;随着蓝牙技术的普及&#xff0c;其安全性和隐私保护问题也日益凸显。本文将探讨蓝牙模块在数据传输过程中的安全性问题&#xff0c;分析隐私保…

Web应用安全测试-业务功能滥用(二)

Web应用安全测试-业务功能滥用&#xff08;二&#xff09; 7、未验证的URL跳转 漏洞描述&#xff1a;服务端未对传入的跳转url变量进行检查和控制&#xff0c;可能导致可恶意构造任意一个恶意地址&#xff0c;诱导用户跳转到恶意网站。由于是从可信的站点跳转出去的&#xff…

如何扩展自己的外部竞争力

前言 程序员是一个需要不断学习的职业&#xff0c;面对层出不穷的新技术&#xff0c;假如你不能够保持一个不断学习的热情。那么&#xff0c;在未来的就业市场中&#xff0c;可能优势会不太明显。那么&#xff0c;除了提高自己内部的技术竞争力外&#xff0c;有什么渠道可以提…

Linux下的GPIO编程

目录 一、前言 二、sysfs方式 1、sysfs简介 2、基本目录结构 3、编号计算 4、sysfs方式控制GPIO 三、libgpiod库 1、libgpiod库简介 2、API函数 四、LED灯编程 一、前言 在Linux下&#xff0c;我们通常使用 sysfs 和 libgpiod库 两种方式进行控制GPIO&#xff0c;目前…

哈喽GPT-4o——对GPT-4o Prompt的思考与看法

目录 一、提示词二、提示词的优势1、提升理解能力2、增强专注力3、提高效率 三、什么样的算无效提示词&#xff1f;1、过于宽泛2、含糊不清3、太过复杂4、没有具体上下文5、缺乏明确目标6、过于开放7、使用专业术语但未定义8、缺乏相关性&#xff1a; 四、提示词正确的编写步骤…

ofd文件预览

文件列表 <template><div><div classfile v-if$myUtils.coll.isNotEmpty(filesList)><div classfile-view><div classfile-view-item :style{justifyContent: align } v-for(item, index) in filesList :keyindex><img classfile-view-item-…

纵深发力 持续推进,富格林平台发展势头喜人

自2024年2月1日正式上线以来,富格林互联网投融资平台已迅速崛起,吸引了业内专家学者的高度认可以及广大投资者的青睐。平台规模持续扩大,目前累计注册用户已超过10万人,总投资额突破50亿美元。这一卓越表现不仅体现了平台的稳健运营和出色的投资项目,也展示了其在互联网投融资领…