`
chinrui
  • 浏览: 98027 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

排序二叉树

阅读更多
#include <iostream>
#include <stdlib.h>

using namespace std;

typedef int Elemtype;
struct TNode {
    Elemtype data;
    struct TNode *lChild, *rChild;
};
typedef struct Head {
    TNode *root;
} *Tree;

//函数声明
Tree init();
TNode * initNode();
void displayDESC(TNode *);
void add(Tree , Elemtype);
void displayASC(TNode *);

int main()
{
    Tree tree = init();
    int iSize;
    Elemtype insertValue;
    cout << "请输入要插入结点数:" << endl;
    cin >> iSize;
    for(int i = 0; i < iSize; i++) {
        cin >> insertValue;
        add(tree , insertValue);
    }
    cout << "排序后的树为(从小到大):" << endl;
    displayDESC(tree->root);
    cout << endl;
    cout << "排序后的树为(从大到小):" << endl;
    displayASC(tree->root);
    return 0;
}

//初始化一棵树
Tree init() {
    Tree t = (Tree)malloc(sizeof(Head));
    t->root = NULL;
    return t;
}

//初始化一个树结点
TNode * initNode() {
    TNode *t = (TNode *)malloc(sizeof(TNode));
    t->lChild = NULL;
    t->rChild = NULL;
    return t;
}

//从小到大展示树中所有元素
void displayDESC(TNode *root) {
    if(root == NULL) {
        return;
    }
    displayDESC(root->lChild);
    cout << root->data << " ";
    displayDESC(root->rChild);
}

//从大到小展示树中所有元素
void displayASC(TNode *root) {
    if(root == NULL) {
        return;
    }
    displayASC(root->rChild);
    cout << root->data << " ";
    displayASC(root->lChild);
}

//向树中添加元素结点
void add(Tree tree , Elemtype value) {
    //如果没有指向根结点的指针,直接返回
    if(tree == NULL) {
        return;
    }

    //初始化要插入的数据为一个树结点
    TNode *t = initNode();
    t->data = value;

    //如果没有根结点,把要插入的结点当作根结点插入
    if(tree->root == NULL) {
        tree->root = t;
        return;
    }

    //将要插入的点与树中的各结点值进行比较,小的放左树,大的放右树
    TNode *tCurr = tree->root;

    while(tCurr != NULL) {
        if(t->data <= tCurr->data) {
            if(tCurr->lChild != NULL) {
                tCurr = tCurr->lChild;
                continue;
            } else {
                tCurr->lChild = t;
                break;
            }
        } else {
            if(tCurr->rChild != NULL) {
                tCurr = tCurr->rChild;
                continue;
            } else {
                tCurr->rChild = t;
                break;
            }
        }
    }
}
分享到:
评论

相关推荐

    排序二叉树的建立和遍历

    ### 排序二叉树的建立与遍历详解 #### 一、概念解析 排序二叉树(Binary Search Tree,简称BST),是一种特殊的二叉树数据结构,其中每个节点具有以下特性: - 节点的左子树上所有节点的值均小于它的根节点的值; -...

    java基础数据结构-排序二叉树

    ### Java基础数据结构—排序二叉树 #### 排序二叉树定义 排序二叉树(也称为二叉搜索树或BST),是一种特殊的二叉树数据结构,它具有以下特性: 1. **节点的数据**:每个节点所含有的数据都是可比较的。 2. **根...

    排序二叉树模板实现

    我自己写的排序二叉树,使用模板,经过g++正确编译

    C++排序二叉树模板

    在这个“C++排序二叉树模板”中,我们将会探讨二叉树的基本概念、常用操作以及如何在C++中实现这些操作。 首先,我们要了解二叉排序树(Binary Search Tree,BST)。这是一种特殊的二叉树,其中每个节点的值都大于...

    数据结构 作业哈夫曼、排序二叉树

    根据给定的文件信息,我们可以总结出以下关于“哈夫曼编码”与“排序二叉树”的相关知识点。 ### 哈夫曼编码 #### 定义 哈夫曼编码是一种广泛使用的数据压缩方法,其核心思想是通过构建一棵哈夫曼树来实现对数据的...

    使用JavaScript实现的排序二叉树.zip

    在计算机科学中,排序二叉树(Sorted Binary Tree)是一种特殊的二叉树数据结构,它满足以下特性:每个节点的左子树上所有节点的值都小于当前节点的值,而右子树上所有节点的值都大于当前节点的值。这种特性使得排序...

    陈斌才---排序二叉树

    根据给定的文件信息,我们可以总结出以下关于“排序二叉树”的相关知识点: ### 排序二叉树(Binary Search Tree, BST)简介 排序二叉树是一种特殊的二叉树,它具有以下特点: - 每个节点包含一个关键字(本例中的...

    平衡排序二叉树的C++算法实现

    平衡排序二叉树是一种特殊的二叉树数据结构,其主要目的是在插入和删除节点时保持树的平衡,以确保在动态查找表中的高效性能。本文将详细讲解平衡排序二叉树的C++实现,特别是如何处理插入和删除操作时的平衡化问题...

    数据结构中用MFC 界面的排序二叉树

    排序二叉树是一种特殊类型的二叉树,它在数据结构中扮演着重要角色,特别是在需要快速查找、插入和删除操作的场景下。MFC(Microsoft Foundation Classes)是微软提供的C++库,用于构建Windows应用程序的用户界面,...

    Java基础复习笔记10数据结构-排序二叉树

    【Java基础复习笔记10数据结构-排序二叉树】 排序二叉树是一种特殊类型的二叉树,其每个节点的数据值满足以下特性:对于任意节点,其左子树中的所有节点值都小于该节点,而右子树中的所有节点值都大于或等于该节点...

    排序二叉树前序中序后序遍历

    排序二叉树,又称有序二叉树或二叉搜索树,是一种二叉树,其特性是左子树上所有节点的值都小于父节点的值,而右子树上所有节点的值都大于父节点的值。这种结构使得排序二叉树在查找、插入和删除操作上具有较高的效率...

    排序二叉树, 数据结构中的hello world

    **排序二叉树详解** 排序二叉树,也被称为有序二叉树,是二叉树数据结构的一个特殊类型。在排序二叉树中,每个节点的左子树只包含小于当前节点值的节点,而右子树则包含大于当前节点值的节点。这种特性使得排序...

    排序二叉树的应用数据结构课程设计报告.doc

    排序二叉树的应用数据结构课程设计报告 排序二叉树是一种重要的数据结构,它广泛应用于计算机科学和软件工程领域中。在本报告中,我们将详细介绍排序二叉树的应用、设计和实现。 一、设计任务 在设计排序二叉树时...

    排序二叉树完整代码

    本代码涵盖二叉查找树的创建,插入,删除,添加,遍历等操作,结合http://blog.csdn.net/wenqian1991/article/details/18228309 可理解

    排序二叉树的应用-数据结构课程设计报告.doc

    【排序二叉树的应用】 排序二叉树,也称为有序二叉树,是一种特殊类型的二叉树,其中每个节点的左子树只包含小于当前节点的元素,而右子树包含大于当前节点的元素。这样的数据结构使得排序二叉树在插入、删除和查找...

    排序二叉树&平衡树

    根据给定的文件信息,我们可以总结出以下关于“排序二叉树&平衡树”的相关知识点,尤其是通过C语言实现的角度: ### 排序二叉树(Binary Search Tree, BST) #### 定义与结构 排序二叉树是一种特殊的二叉树,其中...

    基于JavaScript实现排序二叉树源码.zip

    二叉排序树的建立基于JavaScript实现排序二叉树源码.zip基于JavaScript实现排序二叉树源码.zip基于JavaScript实现排序二叉树源码.zip基于JavaScript实现排序二叉树源码.zip基于JavaScript实现排序二叉树源码.zip

    MFC 排序二叉树实验.pdf

    MFC 排序二叉树实验.pdf

Global site tag (gtag.js) - Google Analytics