c++实现二叉搜索树
自己实现了一下二叉搜索树的数据结构。记录一下:
#include <iostream>
using namespace std;
struct TreeNode{
    int val;
    TreeNode *left;
    TreeNode *right;
    TreeNode(int value) { val=value; left=NULL; right=NULL; }
};
class SearchTree{
public:
    SearchTree();
    ~SearchTree();
    void Destory(TreeNode *);
    void Insertnode(int);
    void Preorder(TreeNode *);
    void Inorder(TreeNode *);
    void Postorder(TreeNode *);
    void Predisplay();
    void Indisplay();
    void Postdisplay();
private:
    TreeNode *root;
};
SearchTree::SearchTree()
{
    root=NULL;
}
SearchTree::~SearchTree()
{
    cout<<"析构二叉搜索树:"<<endl;
    Destory(root);
}
void SearchTree::Destory(TreeNode *node)
{
    if(node!=NULL)
    {
        Destory(node->left);
        Destory(node->right);
        cout<<node->val<<" ";
        delete node;
    }
}
void SearchTree::Insertnode(int value)
{
    if(root==NULL)
        root=new TreeNode(value);
    else
    {
        TreeNode *p,*pre;
        pre=p=root;
        while(p)
        {
            if(p->val==value)
                return;
            else if(p->val>value)
            {
                pre=p;
                p=p->left;
            }
            else
            {
                pre=p;
                p=p->right;
            }
        }
        p=new TreeNode(value);
        if(pre->val>value)
            pre->left=p;
        else
            pre->right=p;
    }
}
void SearchTree::Predisplay()
{
    Preorder(root);
}
void SearchTree::Preorder(TreeNode *root)
{
    if(root)
    {
        cout<<root->val<<" ";
        Preorder(root->left);
        Preorder(root->right);
    }
}
void SearchTree::Indisplay()
{
    Inorder(root);
}
void SearchTree::Inorder(TreeNode *root)
{
    if(root)
    {
        Inorder(root->left);
        cout<<root->val<<" ";
        Inorder(root->right);
    }
}
void SearchTree::Postdisplay()
{
    Postorder(root);
}
void SearchTree::Postorder(TreeNode *root)
{
    if(root)
    {
        Postorder(root->left);
        Postorder(root->right);
        cout<<root->val<<" ";
    }
}
int main()
{
    SearchTree t;
    int a[]={7,4,2,3,15,35,6,45,55,20,1,14};
    int n=sizeof(a)/sizeof(a[0]);
    cout<<"构造二叉搜索树:"<<endl;
    for(int i=0;i<n;++i)
    {
        cout<<a[i]<<" ";
        t.Insertnode(a[i]);
    }
    cout<<endl<<"先序遍历序列: "<<endl;
    t.Predisplay();
    cout<<endl<<"中序遍历序列: "<<endl;
    t.Indisplay();
    cout<<endl<<"后序遍历序列: "<<endl;
    t.Postdisplay();
    cout<<endl;
    return 0;
}
c++实现二叉搜索树的更多相关文章
- [数据结构]——二叉树(Binary Tree)、二叉搜索树(Binary Search Tree)及其衍生算法
		二叉树(Binary Tree)是最简单的树形数据结构,然而却十分精妙.其衍生出各种算法,以致于占据了数据结构的半壁江山.STL中大名顶顶的关联容器--集合(set).映射(map)便是使用二叉树实现 ... 
- [LeetCode] Serialize and Deserialize BST 二叉搜索树的序列化和去序列化
		Serialization is the process of converting a data structure or object into a sequence of bits so tha ... 
- [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 ... 
- [LeetCode] Convert Sorted Array to Binary Search Tree 将有序数组转为二叉搜索树
		Given an array where elements are sorted in ascending order, convert it to a height balanced BST. 这道 ... 
- [LeetCode] Recover Binary Search Tree 复原二叉搜索树
		Two elements of a binary search tree (BST) are swapped by mistake. Recover the tree without changing ... 
- [LeetCode] Validate Binary Search Tree 验证二叉搜索树
		Given a binary tree, determine if it is a valid binary search tree (BST). Assume a BST is defined as ... 
- [LeetCode] Unique Binary Search Trees 独一无二的二叉搜索树
		Given n, how many structurally unique BST's (binary search trees) that store values 1...n? For examp ... 
随机推荐
- jquery 跳转页面传值的问题
			关于 跳转页面传值的问题 1. 目前最多的是使用 ajax 方法 //举例 ajax 传值,举例: $.ajax({ type : "post", url : "save ... 
- js 清空div
			document.getElementById('BIGDraw').innerHTML = ""; $('#BIGDraw').html(""); $('#B ... 
- webpack-dev-server 支持其他设备访问配置
			webpack-dev-server 打开的服务默认是只能localhost访问的,当有时候需要让别人访问的时候可以配置 --host 192.168.84 这样在同一个局域网下面就可以通过该ip来访 ... 
- 使用filter: blur() 的时候解决图片周围泛白和容器外范围变模糊的问题
			类似于这种,这个时候出现了周围变模糊,并且边缘泛白的情况 周围模糊这个问题很好解决,给父容器加overflow:hidden:就可以了 效果如上,至于周围泛白的问题就需要动点脑筋了,给目标添加 tra ... 
- python大数据挖掘系列之基础知识入门
			preface Python在大数据行业非常火爆近两年,as a pythonic,所以也得涉足下大数据分析,下面就聊聊它们. Python数据分析与挖掘技术概述 所谓数据分析,即对已知的数据进行分析 ... 
- VijosP1303 导弹拦截
			背景 实中编程者联盟为了培养技术精湛的后备人才,必须从基础题开始训练. 描述 某国为了防御敌国的导弹袭击,研发出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度, ... 
- jquery封装的图片切换js
			原文发布时间为:2010-10-09 -- 来源于本人的百度文章 [由搬家工具导入] http://jquery.malsup.com/cycle/browser.html 
- JavaScript效果下载网站!
			原文发布时间为:2009-07-16 -- 来源于本人的百度文章 [由搬家工具导入] http://myjs.chinaz.com/ 
- Docker(一):什么是docker
			Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目.它基于 Google 公司推出的 Go 语言实现. 项目后来加入了 Linux 基金会,遵从了 ... 
- JDBC连接池&DBUtils使用
			使用连接池改造JDBC的工具类: 1.1.1 需求: 传统JDBC的操作,对连接的对象销毁不是特别好.每次创建和销毁连接都是需要花费时间.可以使用连接池优化的程序. * 在程序开始的 ... 
