Binary search tree
#ifndef __TREE_H
#define __TREE_H
#include <iostream> template<typename T> class TreeNode {
private:
T _data;
TreeNode<T>* _left;
TreeNode<T>* _right;
TreeNode<T>* _parent;
public:
TreeNode(T data,
TreeNode<T>* parent=,
TreeNode<T>* left=,
TreeNode<T>* right=)
:_data(data),_parent(parent),_left(left),_right(right) {}
void insertAtLeft(T data);
void insertAtRight(T data);
T& getData();
TreeNode<T>*& getLeft();
TreeNode<T>*& getRight();
TreeNode<T>*& getParent();
}; template<typename T>
T& TreeNode<T>::getData()
{
return _data;
} template<typename T>
TreeNode<T>*& TreeNode<T>::getLeft()
{
return _left;
} template<typename T>
TreeNode<T>*& TreeNode<T>::getRight()
{
return _right;
} template<typename T>
TreeNode<T>*& TreeNode<T>::getParent()
{
return _parent;
} template<typename T>
void TreeNode<T>::insertAtLeft(T data)
{
_left = new TreeNode(data,this);
} template<typename T>
void TreeNode<T>::insertAtRight(T data)
{
_right = new TreeNode(data,this);
} template <typename T> class Tree{
private:
TreeNode<T>* _root;
int _size;
protected:
TreeNode<T>* findIn(TreeNode<T>* position,T element) const;
/*
* The last tmp argument is necessary,
* it is used here to changed the parent's _left/_right field
* to potint the node which is created
*/
TreeNode<T>* insertIn(TreeNode<T>* position,
T element,TreeNode<T>* tmp);
void travIn(TreeNode<T>* position);
void travPrev(TreeNode<T>* position);
void travPost(TreeNode<T>* position);
public:
Tree(T data)
:_root(new TreeNode<T> (data)),_size() { }
TreeNode<T>* find(T element) const;
TreeNode<T>* findMax() const;
TreeNode<T>* findMin() const;
TreeNode<T>* insert(T data);
void traversalIn();
void traversalPrev();
void traversalPost();
}; template<typename T>
void Tree<T>::travIn(TreeNode<T>* position)
{
if(!position)
return ;
travIn(position->getLeft());
std::cout << position->getData() << " ";
travIn(position->getRight());
} template<typename T>
void Tree<T>::travPrev(TreeNode<T>* position)
{
if(!position)
return ;
std::cout << position->getData() << " ";
travPrev(position->getLeft());
travPrev(position->getRight());
} template<typename T>
void Tree<T>::travPost(TreeNode<T>* position)
{
if(!position)
return ;
travPost(position->getLeft());
travPost(position->getRight());
std::cout << position->getData() << " ";
} template<typename T>
void Tree<T>::traversalPost()
{
travPost(_root);
std::cout << std::endl;
} template<typename T>
void Tree<T>::traversalPrev()
{
travPrev(_root);
std::cout << std::endl;
} template<typename T>
void Tree<T>::traversalIn()
{
travIn(_root);
std::cout << std::endl;
} template<typename T>
TreeNode<T>* Tree<T>::insertIn(TreeNode<T>* position,T data,
TreeNode<T>* tmp)
{
if(!position){
if(!tmp)
return new TreeNode<T>(data);
else
return (tmp->getData() >data ? tmp->getLeft():tmp->getRight())
= new TreeNode<T>(data,tmp);
}
if(data < position->getData())
insertIn(position->getLeft(),data,position);
else if(position->getData() < data)
insertIn(position->getRight(),data,position);
else
return position;
}
template<typename T>
TreeNode<T>* Tree<T>::insert(T data)
{
return insertIn(_root,data,);
} template<typename T>
TreeNode<T>* Tree<T>::findIn(TreeNode<T>* position,T data)const
{
while(position && position->getData() != data)
{
if(position->getData() > data)
position = position->getLeft();
else if(position->getData() < data)
position = position->getRight();
}
return position;
} template<typename T>
TreeNode<T>* Tree<T>::find(T data) const
{
return findIn(_root,data);
} template<typename T>
TreeNode<T>* Tree<T>::findMax() const
{
TreeNode<T>* tmp = _root;
while(tmp->getRight())
tmp = tmp->getRight();
return tmp;
} template<typename T>
TreeNode<T>* Tree<T>::findMin() const
{
TreeNode<T>* tmp = _root;
while(tmp->getLeft())
tmp = tmp->getLeft();
return tmp;
} #endif
二叉搜索树
Binary search tree的更多相关文章
- [数据结构]——二叉树(Binary Tree)、二叉搜索树(Binary Search Tree)及其衍生算法
二叉树(Binary Tree)是最简单的树形数据结构,然而却十分精妙.其衍生出各种算法,以致于占据了数据结构的半壁江山.STL中大名顶顶的关联容器--集合(set).映射(map)便是使用二叉树实现 ...
- Leetcode 笔记 99 - Recover Binary Search Tree
题目链接:Recover Binary Search Tree | LeetCode OJ Two elements of a binary search tree (BST) are swapped ...
- Leetcode 笔记 98 - Validate Binary Search Tree
题目链接:Validate Binary Search Tree | LeetCode OJ Given a binary tree, determine if it is a valid binar ...
- Leetcode: Convert sorted list to binary search tree (No. 109)
Sept. 22, 2015 学一道算法题, 经常回顾一下. 第二次重温, 决定增加一些图片, 帮助自己记忆. 在网上找他人的资料, 不如自己动手. 把从底向上树的算法搞通俗一些. 先做一个例子: 9 ...
- [LeetCode] Closest Binary Search Tree Value II 最近的二分搜索树的值之二
Given a non-empty binary search tree and a target value, find k values in the BST that are closest t ...
- [LeetCode] Closest Binary Search Tree Value 最近的二分搜索树的值
Given a non-empty binary search tree and a target value, find the value in the BST that is closest t ...
- [LeetCode] Verify Preorder Sequence in Binary Search Tree 验证二叉搜索树的先序序列
Given an array of numbers, verify whether it is the correct preorder traversal sequence of a binary ...
- [LeetCode] Lowest Common Ancestor of a Binary Search Tree 二叉搜索树的最小共同父节点
Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in the BS ...
- [LeetCode] Binary Search Tree Iterator 二叉搜索树迭代器
Implement an iterator over a binary search tree (BST). Your iterator will be initialized with the ro ...
- [LeetCode] Convert Sorted List to Binary Search Tree 将有序链表转为二叉搜索树
Given a singly linked list where elements are sorted in ascending order, convert it to a height bala ...
随机推荐
- animate 实现滑动切换效果
今天和大家分享一下用 animate 实现滑动切换效果的小例子 ------- 来自<一只有梦想的前端小白> 大家都知道jQuery 提供的有一下几种方法能够实现滑动效果: slideDo ...
- SAP (ABAP) 常用的数学函数
Function func Return value abs Absolute value of the argument arg (绝对值) sign Plus/minus sign of the ...
- [SQL] SQL Server 触发器
触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程.触发器主要是通过事件进行触发被自动调用执行的.而存储过程可以通过存储过程的名称被调用. Ø 什么是触发器 触发器对表进行插入.更新.删 ...
- Atitit.iso格式蓝光 BDMV 结构说明
Atitit.iso格式蓝光 BDMV 结构说明 1. Iso是个复合文件1 2. Iso内部格式如下1 2.1. Bdmv文件夹格式 BDMV(Blu-ray Disk Movie.BD-MV),为 ...
- Tint(着色器)的兼容实现
我们在做控件的时候可以使用tint这个属性给控件上色,这样在很多情况下能减少不同色彩的资源色彩.在MD设计中,控件颜色随着主体改变也是一大要点,今天我们就来看看如何使用它. 使用步骤:1.建立一个控件 ...
- IOS常用第三方开源类库&组件
1.AFNetworking AFNetworking 采用 NSURLConnection + NSOperation, 主要方便与服务端 API 进行数据交换, 操作简单, 功能强大, 现在许多人 ...
- Android 尺寸单位转换和屏幕适配相关
Android 尺寸单位转换和屏幕适配相关 各种尺寸单位的意义 dp: Density-independent Pixels 一个抽象的单元,基于屏幕的物理密度. (dp和dip的意义相同,所以不用区 ...
- Android 国际化
由于公司的项目是投放 google play store , 所以要做国际化.国际化遇到的两个大问题 字符串国际化 布局样式国际化 一:字符串国际化 解决这个问题很简单,在res目录下放 ...
- 调用meitu秀秀.so文件实现美图功能
本文属于实战系列,是对<Android C代码回调java方法>等文的实践,调用meitu秀秀的libmtimage-jni.so文件来实现图片的美化功能 首先反编译得到/libmtima ...
- 苹果IPSW文件提取软件
ipsw文件 提取系统文件 方法总结 由于修改运营商文件造成我的有锁4S无法使用移动卡了,在网上苦寻一番还是没有结果,最后萌生了从固件中提取文件的想法,于是便开始在网上搜集资料,最后文件终于提取成功并 ...