#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基础数据结构—排序二叉树 #### 排序二叉树定义 排序二叉树(也称为二叉搜索树或BST),是一种特殊的二叉树数据结构,它具有以下特性: 1. **节点的数据**:每个节点所含有的数据都是可比较的。 2. **根...
我自己写的排序二叉树,使用模板,经过g++正确编译
在这个“C++排序二叉树模板”中,我们将会探讨二叉树的基本概念、常用操作以及如何在C++中实现这些操作。 首先,我们要了解二叉排序树(Binary Search Tree,BST)。这是一种特殊的二叉树,其中每个节点的值都大于...
根据给定的文件信息,我们可以总结出以下关于“哈夫曼编码”与“排序二叉树”的相关知识点。 ### 哈夫曼编码 #### 定义 哈夫曼编码是一种广泛使用的数据压缩方法,其核心思想是通过构建一棵哈夫曼树来实现对数据的...
在计算机科学中,排序二叉树(Sorted Binary Tree)是一种特殊的二叉树数据结构,它满足以下特性:每个节点的左子树上所有节点的值都小于当前节点的值,而右子树上所有节点的值都大于当前节点的值。这种特性使得排序...
根据给定的文件信息,我们可以总结出以下关于“排序二叉树”的相关知识点: ### 排序二叉树(Binary Search Tree, BST)简介 排序二叉树是一种特殊的二叉树,它具有以下特点: - 每个节点包含一个关键字(本例中的...
平衡排序二叉树是一种特殊的二叉树数据结构,其主要目的是在插入和删除节点时保持树的平衡,以确保在动态查找表中的高效性能。本文将详细讲解平衡排序二叉树的C++实现,特别是如何处理插入和删除操作时的平衡化问题...
排序二叉树是一种特殊类型的二叉树,它在数据结构中扮演着重要角色,特别是在需要快速查找、插入和删除操作的场景下。MFC(Microsoft Foundation Classes)是微软提供的C++库,用于构建Windows应用程序的用户界面,...
【Java基础复习笔记10数据结构-排序二叉树】 排序二叉树是一种特殊类型的二叉树,其每个节点的数据值满足以下特性:对于任意节点,其左子树中的所有节点值都小于该节点,而右子树中的所有节点值都大于或等于该节点...
排序二叉树,又称有序二叉树或二叉搜索树,是一种二叉树,其特性是左子树上所有节点的值都小于父节点的值,而右子树上所有节点的值都大于父节点的值。这种结构使得排序二叉树在查找、插入和删除操作上具有较高的效率...
**排序二叉树详解** 排序二叉树,也被称为有序二叉树,是二叉树数据结构的一个特殊类型。在排序二叉树中,每个节点的左子树只包含小于当前节点值的节点,而右子树则包含大于当前节点值的节点。这种特性使得排序...
排序二叉树的应用数据结构课程设计报告 排序二叉树是一种重要的数据结构,它广泛应用于计算机科学和软件工程领域中。在本报告中,我们将详细介绍排序二叉树的应用、设计和实现。 一、设计任务 在设计排序二叉树时...
本代码涵盖二叉查找树的创建,插入,删除,添加,遍历等操作,结合http://blog.csdn.net/wenqian1991/article/details/18228309 可理解
【排序二叉树的应用】 排序二叉树,也称为有序二叉树,是一种特殊类型的二叉树,其中每个节点的左子树只包含小于当前节点的元素,而右子树包含大于当前节点的元素。这样的数据结构使得排序二叉树在插入、删除和查找...
根据给定的文件信息,我们可以总结出以下关于“排序二叉树&平衡树”的相关知识点,尤其是通过C语言实现的角度: ### 排序二叉树(Binary Search Tree, BST) #### 定义与结构 排序二叉树是一种特殊的二叉树,其中...
二叉排序树的建立基于JavaScript实现排序二叉树源码.zip基于JavaScript实现排序二叉树源码.zip基于JavaScript实现排序二叉树源码.zip基于JavaScript实现排序二叉树源码.zip基于JavaScript实现排序二叉树源码.zip
MFC 排序二叉树实验.pdf