C数据结构与算法——二叉树 应用一

实验任务

(1) 掌握二叉树的二叉链表存储结构定义;
(2) 掌握该存储方式下的二叉树基本算法;
(3) 掌握三种遍历的递归算法。

实验内容

  1. 实现二叉链表存储结构及其基本算法
  2. 算法简单应用
    • 创建一颗二叉树的二叉链表
    • 输出该二叉树的三种遍历序列(前、中、后序 遍历)

实验源码

#include <stdio.h>
#include <malloc.h>

typedef struct BiTNode {
    char data;
    struct BiTNode *lChild, *rChild;
} BiTNode, *BiTree;


void InitBiTree(BiTree *tree);

void CreateBiTree(BiTree *tree);

BiTree InsertLeftNode(BiTree tree, char data);

BiTree InsertRightNode(BiTree tree, char data);

void PreOrderTraverse(BiTree tree);

void InOrderTraverse(BiTree tree);

void PostOrderTraverse(BiTree tree);

void VisitNode(BiTree tree);


/**
 * <h2>二叉树实验一</h2>
 * <h3>左右插入结点法</h3>
 * @return 0
 */
int main() {

    // 定义一棵二叉树
    BiTree tree;

    // 初始化
    InitBiTree(&tree);

    // 创建二叉树
    CreateBiTree(&tree);

    // 前序遍历
    printf("前序遍历:");
    PreOrderTraverse(tree);
    printf("\n");

    // 中序遍历
    printf("中序遍历:");
    InOrderTraverse(tree);
    printf("\n");

    // 后序遍历
    printf("后序遍历:");
    PostOrderTraverse(tree);
    printf("\n");

    return 0;
}

void InitBiTree(BiTree *tree) {
    *tree = NULL;
}

void CreateBiTree(BiTree *tree) {
    *tree = InsertLeftNode(*tree, 'A');
    *tree = InsertLeftNode(*tree, 'B');
    *tree = InsertLeftNode(*tree, 'E');
    (*tree)->lChild->lChild = InsertRightNode((*tree)->lChild->lChild, 'F');
    (*tree)->lChild = InsertRightNode((*tree)->lChild, 'C');
    (*tree)->lChild = InsertRightNode((*tree)->lChild, 'D');
    (*tree)->lChild->rChild->rChild = InsertLeftNode((*tree)->lChild->rChild->rChild, 'G');
}

// 左插入
BiTree InsertLeftNode(BiTree tree, char data) {
    if (tree != NULL) {
        // 遍历左孩子
        tree->lChild = InsertLeftNode(tree->lChild, data);
    } else {
        // 插入结点到左孩子
        tree = (BiTree) malloc(sizeof(BiTNode));
        if (tree == NULL) {
            return NULL;
        }
        tree->data = data;
        tree->lChild = tree->rChild = NULL;
    }
    return tree;
}

// 右插入
BiTree InsertRightNode(BiTree tree, char data) {
    if (tree != NULL) {
        // 遍历右孩子
        tree->rChild = InsertRightNode(tree->rChild, data);
    } else {
        // 插入结点到右孩子
        tree = (BiTree) malloc(sizeof(BiTNode));
        if (tree == NULL) {
            return NULL;
        }
        tree->data = data;
        tree->lChild = tree->rChild = NULL;
    }
    return tree;
}

void PreOrderTraverse(BiTree tree) {
    if (tree != NULL) {
        VisitNode(tree); // 前序
        PreOrderTraverse(tree->lChild);
        PreOrderTraverse(tree->rChild);
    }
}

void InOrderTraverse(BiTree tree) {
    if (tree != NULL) {
        InOrderTraverse(tree->lChild);
        VisitNode(tree); // 中序
        InOrderTraverse(tree->rChild);
    }
}

void PostOrderTraverse(BiTree tree) {
    if (tree != NULL) {
        PostOrderTraverse(tree->lChild);
        PostOrderTraverse(tree->rChild);
        VisitNode(tree); // 后序
    }
}

void VisitNode(BiTree tree) {
    printf("%c ", tree->data);
}

实验结果

在这里插入图片描述

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

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

相关文章

flutter-第三方组件

卡片折叠 stacked_card_carousel 扫一扫组件 qr_code_scanner 权限处理组件 permission_handler 生成二维码组件 pretty_qr_code 角标组件 badges 动画组件 animations app更新 app_installer 带缓存的图片组件 cached_network_image 密码输入框 collection 图片保存 image_g…

前端安全XSS和CSRF讲解

文章目录 XSSXSS攻击原理常见的攻击方式预防措施 CSRFCSRF攻击原理常见攻击情景预防措施&#xff1a; CSRF和XSS的区别 XSS 全称Cross Site Scripting&#xff0c;名为跨站脚本攻击。为啥不是单词第一个字母组合CSS&#xff0c;大概率与样式名称css进行区分。 XSS攻击原理 不…

ppt压缩文件怎么压缩最小?文件压缩技巧分享

在日常的工作和学习中&#xff0c;难免会遇到PPT太大&#xff0c;需要将其压缩变小的情况&#xff0c;但很多朋友还不知道怎么压缩PPT文件&#xff0c;下面就给大家分享几个简单的方法&#xff0c;分分钟缩小过大的PPT文件。 一、PowerPoint PowerPoint就是微软公司的演示文稿…

无涯教程-Perl - gethostent函数

描述 此函数遍历主机文件中的条目。它在列表context中返回以下内容-($name,$aliases,$addrtype,$length,addrs) 语法 以下是此函数的简单语法- gethostent返回值 此函数在错误时返回undef,否则在scalrcontext中返回主机名,在错误时返回空列表,否则在列表context中返回主机…

基于CAS的单点登录实践之路

前言 上个月我负责的系统SSO升级&#xff0c;对接京东ERP系统&#xff0c;这也让我想起了之前我做过一个单点登录的项目。想来单点登录有很多实现方案&#xff0c;不过最主流的还是基于CAS的方案&#xff0c;所以我也就分享一下我的CAS实践之路。 什么是单点登录 单点登录的…

怎么进行流程图制作?用这个工具制作很方便

怎么进行流程图制作&#xff1f;流程图是一种非常有用的工具&#xff0c;可以帮助我们更好地理解和展示各种复杂的业务流程和工作流程。它可以将复杂的过程简化为易于理解的图形和文本&#xff0c;使得人们更容易理解和跟踪整个流程。因此&#xff0c;制作流程图是在日常工作中…

抑郁症与肠道微生物群有何关联

谷禾健康 抑郁症肠道菌群 当一个人面临抑郁症时&#xff0c;一切看似平常的事都会变得很有挑战性。上班、与朋友社交&#xff0c;甚至只是起床都感觉很困难。 抑郁症是如今已是世界上最普遍的精神障碍之一&#xff0c;一直是心理学和医学领域的研究热点。抑郁症是一种需要预防和…

探索 TypeScript 元组的用例

元组扩展了数组数据类型的功能。使用元组&#xff0c;我们可以轻松构造特殊类型的数组&#xff0c;其中元素相对于索引或位置是固定类型的。由于 TypeScript 的性质&#xff0c;这些元素类型在初始化时是已知的。使用元组&#xff0c;我们可以定义可以存储在数组中每个位置的数…

浪潮服务器硬盘指示灯显示黄色的服务器数据恢复案例

服务器数据恢复环境&#xff1a; 宁夏某市某单位的一台浪潮服务器&#xff0c;该服务器中有一组由6块SAS硬盘组建的RAID5阵列。 服务器上存放的是Oracle数据库文件&#xff0c;操作系统层面划分了1个卷。 服务器故障&初检&#xff1a; 服务器在运行过程中有两块磁盘的指示灯…

虹科方案 | 成都大运会进行时,保障大型活动无线电安全需要…

成都大运会 7月28日&#xff0c;备受关注的第31届世界大学生夏季运动会在成都正式开幕。据悉&#xff0c;这是全球首个5G加持的智慧大运会&#xff0c;也是众多成熟信息技术的综合“应用场”。使用基于5G三千兆、云网、8K超高清视频等技术&#xff0c;在比赛现场搭建多路8K摄像…

《UNIX 传奇:历史与回忆》读后感

《UNIX 传奇&#xff1a;历史与回忆》 是 bwk&#xff08;Brian W. Kernighan&#xff09;2019 年的新作&#xff0c;回忆了 UNIX 在大半个世纪的风雨历程&#xff0c;是一本引人入胜的书籍。通过对 UNIX 操作系统的历史和发展进行详细的叙述和回顾&#xff0c;让我对这个操作系…

vue table动态合并, 自定义合并,参照合并,组合合并

<template><div><el-table:data"tableData":span-method"objectSpanMethod"border:header-cell-style"{ textAlign: center }"><el-table-column prop"area" label"区域" align"center">…

java动态生成excel并且需要合并单元格

java动态生成excel并且需要合并单元格 先上图看一下预期效果 集成poi <dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-base</artifactId><version>4.0.0</version> </dependency> <dependency><…

为什么Mendix的OQL比SQL更方便,以及如何实现类似MySQL的workbench?

前言 在当今信息时代&#xff0c;数据的价值变得越来越重要。数据处理是任何软件系统都非常关注的核心功能。无论是电子商务网站、移动应用程序还是企业管理系统&#xff0c;这些系统都需要处理和管理大量的数据。例如&#xff0c;当用户在电子商务网站上搜索特定商品时&#…

无涯教程-Perl - formline函数

描述 格式功能和相关的运算符使用此功能。它根据PICTURE的内容将LIST格式化为输出累加器变量$^ A。写入完成后,该值将写出到文件句柄中。 语法 以下是此函数的简单语法- formline PICTURE, LIST返回值 该函数总是返回1。 Perl 中的 formline函数 - 无涯教程网无涯教程网提…

Octave Conv

Octave ConvOctave Convolution 代码详解_octconv代码_zghydx1924的博客-CSDN博客 def forward(self, x):X_h, X_l xif self.stride 2:X_h, X_l self.h2g_pool(X_h), self.h2g_pool(X_l)X_h2l self.h2g_pool(X_h)# X_h2l指的是对输入进行下采样&#xff0c;下采样的方法时卷…

【云原生】kubernetes在Pod中init容器的作用和使用

目录 Pod 中 init 容器 1 init 容器特点 2 使用 init 容器 Pod 中 init 容器 Init 容器是一种特殊容器&#xff0c;在Pod 内的应用容器启动之前运行。Init 容器可以包括一些应用镜像中不存在的实用工具和安装脚本。 1 init 容器特点 init 容器与普通的容器非常像&#xf…

【深度学习】Collage Diffusion,拼接扩散,论文,实战

论文&#xff1a;https://arxiv.org/abs/2303.00262 代码&#xff1a;https://github.com/VSAnimator/collage-diffusion 文章目录 AbstractIntroductionProblem Definition and Goals论文其他内容实战 Abstract 基于文本条件的扩散模型能够生成高质量、多样化的图像。然而&a…

【CSS】CSS 选择器

CSS 选择器 1.基础选择器 1.1 元素选择器 语法&#xff1a;标签名{...} 元素选择器会选中对应标签名的HTML元素&#xff0c;例如&#xff1a;p{...}&#xff0c;div{...}&#xff0c;span{...}等 1.2 类选择器 语法&#xff1a;.类名{...} 类选择器会选中class属性为指定…

【vue3-element-admin】ESLint+Prettier+Stylelint+EditorConfig 约束和统一前端代码

前言 本文介绍 vue3-element-admin 如何通过ESLint 检测 JS/TS 代码、Prettier 格式化代码、Stylelint 检测 CSS/SCSS 代码和配置 EditorConfig 来全方位约束和统一前端代码规范。 ESLint 代码检测 ESLint 可组装的JavaScript和JSX检查工具&#xff0c;目标是保证代码的一致…