二叉树(C++类模板实现)

1. 二叉树的定义

后续更新

2.二叉树的性质

后续更新

3.二叉树的存储结构

  • 顺序存储结构。顺序存储结构使用一组地址连续的存储单元来存储数据元素,为了能够在存储结构中反映出结点之间的逻辑关系,必须将二叉树中的结点依照一定的规律安排在这组单元中。
  • 链式存储结构设计不同的结点结构可构成不同形式的链式存储结构。由二叉树的定义得知,二叉树的结点由一个数据元素和分别指向其左、 右子树的两个分支构成,则表示二叉树的链表
    中的结点至少包含 3 个域:数据域和左、 右指针域。

注意:本文对于二叉树采用链式存储结构实现。(C++)

4. 代码

binary_tree.h
实现二叉树的各种操作

#ifndef BINARY_TREE_H
#define BINARY_TREE_H
#include <iostream>
#include <vector>
#include <array>
using std::vector;
using std::array;
using std::cout;
using std::endl;
using std::cin;
using std::cerr;
template <typename T>
struct BitNode {
   
    /* data */
    T data;
    BitNode* lchild;
    BitNode* rchild;
    BitNode(T data) : data(data), lchild(nullptr), rchild(nullptr) {
   };
};
template <typename T>
class BinaryTree {
   
    private:
        int count;
        void PreOrderTraverse(BitNode<T>* node,void (*visit)(T));//用于先序遍历二叉树
        void MidOrderTraverse(BitNode<T>* node,void (*visit)(T)); //用于中序遍历二叉树
        void EndOrderTraverse(BitNode<T>* node,void (*visit)(T)); //用于后序遍历二叉树
        void LevelOrderTraverse(void (*visit)(T));//用于层序遍历二叉树
        void PreOrderTraverseStack(void (*visit)(T)); //用栈先序遍历二叉树
        void MidOrderTraverseStack(void (*visit)(T)); //用栈中序遍历二叉树
    public:
        BitNode<T>* root;
        BinaryTree() : root(nullptr),count(0){
   }; 
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值