二叉搜索树封装代码

#pragma once
#include <iostream>
using namespace std;
template<class T>class TreeNode {
public:
TreeNode(T value)
{
this->val = value;
this->right = NULL;
this->left = NULL;
}
TreeNode() { }
T val;
TreeNode *left;
TreeNode *right;
}; template<class T>class BST {
public:
BST();
void Insert(T value); //插入元素接口
void InOrder(); //打印中序序列接口
int GetSize(); //返回当前二叉树总元素个数
int GetMaxValue(); //返回当前二叉树的最大值
int GetMinValue(); //返回当前二叉树的最小值
void Delete(T value); //删除该元素
private:
TreeNode<T> *insert(TreeNode<T> *root, T value ); //内部插入实现
TreeNode<T> *deleteval(TreeNode<T> *node, T val); //删除某个元素
TreeNode<T> *FindMin(TreeNode<T> *node); //找到最小的元素的结点
TreeNode<T> *FindMax(TreeNode<T> *node); //找到最大的元素的结点
T getmaxvalue(TreeNode<T> *node);
T getminvalue(TreeNode<T> *node);
void inorder(TreeNode<T> *node); //内部中序遍历
TreeNode<T> *Tree;
int size;
};
template<class T>
inline BST<T>::BST()
{
this->size = 0;
this->Tree = NULL;
} //往BST树中插入数据
template<class T>
inline void BST<T>::Insert(T value)
{
this->Tree = insert(Tree, value);
} template<class T>
inline TreeNode<T> * BST<T>::insert(TreeNode<T> *node, T value)
{
if (node == NULL)
{
size++;
return new TreeNode<T>(value);
}
else {
if (value < node->val)
{
node->left = insert(node->left, value);
return node;
}
else if (value > node->val)
{
node->right = insert(node->right, value);
return node;
}
}
} //获取当前二叉树的所有非空结点
template<class T>
inline int BST<T>::GetSize()
{
return this->size;
} template<class T>
inline int BST<T>::GetMaxValue()
{
return this->getmaxvalue(Tree);
} template<class T>
inline int BST<T>::GetMinValue()
{
return this->getminvalue(Tree);
} template<class T>
inline void BST<T>::Delete(T value)
{
Tree = this->deleteval(Tree, value);
this->size--;
} //中序遍历
template<class T>
inline void BST<T>::InOrder()
{
inorder(Tree);
} template<class T>
inline void BST<T>::inorder(TreeNode<T> *node)
{
if (node != NULL)
{
inorder(node->left);
cout << node->val << " ";
inorder(node->right);
}
} template<class T>
inline TreeNode<T> * BST<T>::deleteval(TreeNode<T>* node, T val)
{
if (node == NULL)cout << "未找到此元素" << endl;
TreeNode<T> *tmp = new TreeNode<T>;
if (val < node->val)
node->left = deleteval(node->left, val);
else if(val > node->val)
node->right = deleteval(node->right, val);
else {
if (node->left != NULL && node->right != NULL) //存在左右子树
{
tmp = this->FindMin(node->right);
node->val = tmp->val;
node->right = deleteval(node->right, node->val);
}
else { //叶子结点或者只有一个子节点
tmp = node;
if (!node->left)
node = node->right;
else if (!node->right)
node = node->left;
free(tmp);
}
}
return node;
} template<class T>
inline TreeNode<T>* BST<T>::FindMin(TreeNode<T>* node)
{
if (node->left == NULL)return node;
else return FindMin(node->left);
} template<class T>
inline TreeNode<T>* BST<T>::FindMax(TreeNode<T>* node)
{
if (node->right == NULL)return node;
else return FindMax(node->right);
} template<class T>
inline T BST<T>::getmaxvalue(TreeNode<T> *node)
{
//如果当前结点的左子树为空树,则当前结点就是最大值
if (node->right == NULL)
return node->val;
else return getmaxvalue(node->right);
} template<class T>
inline T BST<T>::getminvalue(TreeNode<T> *node)
{
if (node->left == NULL)
return node->val;
else return getminvalue(node->left);
}

测试代码

#include <istream>
#include "BST.h"
using namespace std; int main()
{
BST<int> bt;
int arr[] = { 9,5,3,4,1,7,2,8,0 };
int n = sizeof(arr) / sizeof(int);
for (int i = 0; i < n; i++)
bt.Insert(arr[i]);
bt.InOrder();
cout << endl << bt.GetSize() << endl;
cout << "这组元素中的最大值为:" <<bt.GetMaxValue() << endl;
cout << "这组元素中的最小值为:" <<bt.GetMinValue() << endl;
cout << "输入你想删除任意一个元素" << endl;
int x = 0;
cin >> x;
bt.Delete(x);
bt.InOrder();
cout << "此时该集合内的元素个数为:" << bt.GetSize() << endl;
system("pause");
return 0;
}

数据结构 - 二叉搜索树封装 C++的更多相关文章

  1. 数据结构-二叉搜索树(BST binary search tree)

    本文由@呆代待殆原创,转载请注明出处:http://www.cnblogs.com/coffeeSS/ 二叉搜索树简介 顾名思义,二叉搜索树是以一棵二叉树来组织的,这样的一棵树可以用一个链表数据结构来 ...

  2. 数据结构-二叉搜索树的js实现

    一.树的相关概念 1.基本概念 子树 一个子树由一个节点和它的后代构成. 节点的度 节点所拥有的子树的个数. 树的度 树中各节点度的最大值 节点的深度 节点的深度等于祖先节点的数量 树的高度 树的高度 ...

  3. 数据结构☞二叉搜索树BST

    二叉查找树(Binary Search Tree),(又:二叉搜索树,二叉排序树)它可以是一棵空树,也可以是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值: 若它 ...

  4. 基本数据结构 —— 二叉搜索树(C++实现)

    目录 什么是二叉搜索树 二叉搜索树如何储存数值 二叉搜索树的操作 插入一个数值 查询是否包含某个数值 删除某个数值 测试代码 参考资料 什么是二叉搜索树 二叉搜索树(英语:Binary Search ...

  5. 数据结构---二叉搜索树BST实现

    1. 二叉查找树 二叉查找树(Binary Search Tree),也称为二叉搜索树.有序二叉树(ordered binary tree)或排序二叉树(sorted binary tree),是指一 ...

  6. 数据结构-二叉搜索树和二叉树排序算法(python实现)

    今天我们要介绍的是一种特殊的二叉树--二叉搜索树,同时我们也会讲到一种排序算法--二叉树排序算法.这两者之间有什么联系呢,我们一起来看一下吧. 开始之前呢,我们先来介绍一下如何创建一颗二叉搜索树. 假 ...

  7. Java数据结构——二叉搜索树

    定义二叉查找树(Binary Search Tree),(又:二叉搜索树,二叉排序树)它或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值: 若 ...

  8. 数据结构——二叉搜索树(Binary Search Tree)

    二叉树(Binary Tree)的基础下 每个父节点下 左节点小,右节点大. 节点的插入: 若root==NULL则root=newnode 否则不断与节点值比较,较小则向左比较,较大则向右比较. 完 ...

  9. 数据结构-二叉搜索树Java实现

    1,Node.java 生成基础二叉树的结构 package com.cnblogs.mufasa.searchTree; /** * 节点配置父+左+右 */ public class Node{ ...

随机推荐

  1. 【转】使用Hibernate的好处是什么?

    一.Hibernate是JDBC的轻量级的对象封装,它是一个独立的对象持久层框架,和App Server,和EJB没有什么必然的联系.Hibernate可以用在任何JDBC可以使用的场合,例如Java ...

  2. [LeetCode] 62. Unique Paths 不同的路径

    A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...

  3. Spring Boot中的Mongodb多数据源扩展

    在日常工作中,我们通过Spring Data Mongodb来操作Mongodb数据库,在Spring Boot中只需要引入spring-boot-starter-data-mongodb即可. 然后 ...

  4. 一张图入门Python【中文版】

    好久没写了,就拿这张图作为开篇吧,重新梳理自己学习的东西,最近两年人工智能炒红了python,devops的提出也把开发.运维整合到了一起,作为一个运维工程师,随着企业自动化运维的提出,光会shell ...

  5. 错误:PermissionError: [WinError 32] 另一个程序正在使用此文件,进程无法访问。"+文件路径"的解决方案

    最近在使用python进行筛选图片的时候,想到用python里面的os库进行图片的删除. 具体筛选方法就是,删除掉图片长度或宽度小于100像素的图片,示例代码如下所示: for file in os. ...

  6. pytorch-04-激活函数

    sigmoid函数: 越大的负数越接近0,越大的正数越接近1缺点:(1)造成梯度消失:该函数在靠近1和0的两端,梯度几乎变成0,梯度下降法:梯度乘上学习率来更新参数,如果梯度接近0,那么没有任何信息来 ...

  7. linux写shell注意的问题

    linux写shell注意的问题一定要vi crontab.sh来写 ps:在windows系统中编辑过这个文件,就会出现类似的换行符 这样导致linux系统中运行sh报错 比如会出现$MQ字符 如果 ...

  8. 关于wepy小程序图片显示问题

    如果图片资源在本地,用background-image 是无法找到本地资源的,只能通过image标签用src进行引入: 图片资源在服务器上,用背景图片和image进行引入,在安卓真机上测试是没有问题的 ...

  9. Java8 LocalDateTime和Date相互转换

    很想要用Java的时间api,但有时候还是需要转换为Date. 二者的相互转换并不是一步到位那么简单,所以,还是需要记录一下转换的api Date to LocalDateTime Date toda ...

  10. [转帖]centos 7 avahi-daemon服务的作用及如何关闭

    centos 7 avahi-daemon服务的作用及如何关闭 https://blog.csdn.net/tjjingpan/article/details/81237308 关闭 systemct ...