第17章 二叉树,堆和优先队列(1/3)

阅读Liang 教授的Introduction to Programming with C++的总结

  1. 二叉搜索树
  2. 优先队列

    本章主要介绍三种高级数据结构二搜索叉树,堆和优先队列
    1.二叉搜索树
    实现二叉搜索树的构造,查找和遍历。二叉搜索树没有重复元素,对于一个节点(假设为p)来说,其左子树的值小于其父亲节点的值,其右子树的值大于其父亲节点的值。简而言之是:
    (p->lchild->val) <(p->val)
    (p->rchild->val) >(p->val)
    原文代码中还使用到了模版类技术,使得代码有更好的通用性,只要类型T之间能够比较都可以建立二叉搜索树,若类型T不能比较可以重载关系操作符。原文中对于树的遍历使用递归方法遍历的,我们可以使用非递归版本,巩固一下原来的知识。这里需要指出的是,由于二叉搜索树的特性,左子节点比父亲节点小,右子节点比父亲节点大,所以其中跟遍历正好是递增的了。

    二叉树节点数据结构为:

template<typename T>
struct TreeNode{
    T val;
    TreeNode *lchild, *rchild;
    TreeNode(T i): val(i), lchild(nullptr), rchild(nullptr){};
};

再写个辅助函数,方便产生数组和打印结果:

// Create random int array
vector<int> getRand(size_t len,
                    int max,
                    unsigned int seed){
    srand(seed);
    vector<int> res(len, 0);
    for (size_t i = 0; i < len; i++) {
        res[i] = rand() % max;
    }
    return res;
}

// A template function
// print vector
template <typename T = int>
void
printVector(const vector<T>& vec,
            const string& msg = "") {
    cout << msg << ":\t";
    for (auto i: vec) {
        cout << i << " ";
    }
    cout << endl;
}

下面是定义二叉搜索树类了:
两个构造函数,一个是默认构造函数,一个是接受T类型的vect

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值