浙大数据结构:树的定义与操作

2024-09-08 13:52

本文主要是介绍浙大数据结构:树的定义与操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

四种遍历

#include<iostream>
#include<queue>
using namespace std;
typedef struct treenode *BinTree;
typedef BinTree position;
typedef int ElementType;
struct treenode
{ElementType data;BinTree left;BinTree right;treenode(){left=NULL,right=NULL;}
};void inordertraval(BinTree b)
{if(b){inordertraval(b->left);cout<<b->data;inordertraval(b->right);}
}void preordertraval(BinTree b)
{if(b){cout<<b->data;preordertraval(b->left);preordertraval(b->right);}
}void  postordertraval(BinTree b)
{if(b){postordertraval(b->left);postordertraval(b->right);cout<<b->data;}
}void levelordertraval(BinTree b)
{queue<treenode> Q;BinTree B;if(!b)return ;Q.push(*b);while(!Q.empty()){treenode t=Q.front();cout<<t.data;Q.pop();if(t.left)Q.push(*t.left);if(t.right)Q.push(*t.right);}}

树的插入与删除

BinTree Insert( BinTree BST, ElementType X )
{if(!BST){BST=(BinTree)malloc(sizeof(struct TNode));BST->Data=X;BST->Left=BST->Right=NULL;return BST;}if(X < BST->Data)BST->Left=Insert(BST->Left,X);else if(X > BST->Data)BST->Right=Insert(BST->Right,X);return BST;
}BinTree Delete( BinTree BST, ElementType X )
{Position tmp;if(!BST)printf("Not Found\n");else{if(X<BST->Data)BST->Left=Delete(BST->Left,X);else if(X>BST->Data)BST->Right=Delete(BST->Right,X);else {
if(BST->Left&&BST->Right)
{tmp=FindMin(BST->Right);BST->Data=tmp->Data;BST->Right=Delete(BST->Right,BST->Data);}else {tmp=BST;if(!BST->Left)BST=BST->Right;else BST=BST->Left;free(tmp);}}}return BST;
}

查找,查找最小,查找最大

Position Find( BinTree BST, ElementType X )
{if(!BST)return NULL;if(X>BST->Data)return Find(BST->Right,X);else if(X<BST->Data)return Find(BST->Left,X);else return BST;
}Position FindMin( BinTree BST )
{
if(!BST)return NULL;else if(!BST->Left)return BST;else return FindMin(BST->Left);
}Position FindMax( BinTree BST )
{if(!BST)return NULL;else if(!BST->Right)return BST;else return FindMax(BST->Right);
}

这篇关于浙大数据结构:树的定义与操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1148293

相关文章

C# 读写ini文件操作实现

《C#读写ini文件操作实现》本文主要介绍了C#读写ini文件操作实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、INI文件结构二、读取INI文件中的数据在C#应用程序中,常将INI文件作为配置文件,用于存储应用程序的

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

java Stream操作转换方法

《javaStream操作转换方法》文章总结了Java8中流(Stream)API的多种常用方法,包括创建流、过滤、遍历、分组、排序、去重、查找、匹配、转换、归约、打印日志、最大最小值、统计、连接、... 目录流创建1、list 转 map2、filter()过滤3、foreach遍历4、groupingB

Java操作PDF文件实现签订电子合同详细教程

《Java操作PDF文件实现签订电子合同详细教程》:本文主要介绍如何在PDF中加入电子签章与电子签名的过程,包括编写Word文件、生成PDF、为PDF格式做表单、为表单赋值、生成文档以及上传到OB... 目录前言:先看效果:1.编写word文件1.2然后生成PDF格式进行保存1.3我这里是将文件保存到本地后

Python使用Colorama库美化终端输出的操作示例

《Python使用Colorama库美化终端输出的操作示例》在开发命令行工具或调试程序时,我们可能会希望通过颜色来区分重要信息,比如警告、错误、提示等,而Colorama是一个简单易用的Python库... 目录python Colorama 库详解:终端输出美化的神器1. Colorama 是什么?2.

Python视频剪辑合并操作的实现示例

《Python视频剪辑合并操作的实现示例》很多人在创作视频时都需要进行剪辑,本文主要介绍了Python视频剪辑合并操作的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录介绍安装FFmpegWindowsMACOS安装MoviePy剪切视频合并视频转换视频结论介绍

Windows自动化Python pyautogui RPA操作实现

《Windows自动化PythonpyautoguiRPA操作实现》本文详细介绍了使用Python的pyautogui库进行Windows自动化操作的实现方法,文中通过示例代码介绍的非常详细,对大... 目录依赖包睡眠:鼠标事件:杀死进程:获取所有窗口的名称:显示窗口:根据图片找元素:输入文字:打开应用:依

Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南

《Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南》在日常数据处理工作中,我们经常需要将不同Excel文档中的数据整合到一个新的DataFrame中,以便进行进一步... 目录一、准备工作二、读取Excel文件三、数据叠加四、处理重复数据(可选)五、保存新DataFram

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P