阅读Liang 教授的Introduction to Programming with C++的总结
- 二叉搜索树
- 堆
优先队列
本章主要介绍三种高级数据结构二搜索叉树,堆和优先队列
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