二叉树的节点插入比较简单。一般来说,二叉树的插入主要分为以下两个步骤:
1) 对当前的参数进行判断,因为需要考虑到头结点,所以我们使用了指针的指针作为函数的输入参数
2) 分情况讨论:
如果原来二叉树连根节点都没有,那么这个新插入的数据就是根节点;
如果原来的二叉树有根节点,那我们判断这个数据是否存在过,如果存在,那么返回;如果不存在,那么继续插入数据。
那继续插入的数据怎么保存呢?又要分三种情况:
1)如果插入的数据小于当前节点的数据,那么往当前节点的左子树方向继续寻找插入位置
2)如果插入的数据大于当前插入的位置,那么往当前节点的右子树方向继续寻找插入位置
3)如果方向当前的节点为空,那么表示插入的位置找到了,插入数据即可
算法说了这么多,下面即开始练习我们的代码:
a)判断输入数据的合法性
STATUS insert_node_into_tree(TREE_NODE** ppTreeNode, int data)
{
if(NULL == ppTreeNode)
return FALSE;
return TRUE;
}
此时,可以用一个测试用例验证一下
static void test1()
{
assert(FALSE == insert_node_into_tree(NULL, 10));
}
b)判断当前根节点是否存在,修改代码
STATUS insert_node_into_tree(TREE_NODE** ppTreeNode, int data)
{
if(NULL == ppTreeNode)
return FALSE;
if(NULL == *ppTreeNode){
*ppTreeNode = (TREE_NODE*)create_tree_node(data);
assert(NULL != *ppTreeNode);
return TRUE;
}
return TRUE;
}
修改了代码,少不了测试用例的添加。
static void test2()
{
TREE_NODE* pTreeNode = NULL;
assert(TRUE == insert_node_into_tree(&pTreeNode, 10));
assert(10 == pTreeNode->data);
free(pTreeNode);
}
c)上面考虑了没有根节点的情况,那么如果根节点存在呢?
STATUS _insert_node_into_tree(TREE_NODE** ppTreeNode, int data, TREE_NODE* pParent)
{
if(NULL == *ppTreeNode){
*ppTreeNode = create_tree_node(data);
assert(NULL != *ppTreeNode);
(*ppTreeNode)->parent = pParent;
return TRUE;
}
if(data < (*ppTreeNode)->data)
return _insert_node_into_tree(&(*ppTreeNode)->left_child, data, *ppTreeNode);
else
return _insert_node_into_tree(&(*ppTreeNode)->right_child, data, *ppTreeNode);
}
STATUS insert_node_into_tree(TREE_NODE** ppTreeNode, int data)
{
if(NULL == ppTreeNode)
return FALSE;
if(NULL == *ppTreeNode){
*ppTreeNode = (TREE_NODE*)create_tree_node(data);
assert(NULL != *ppTreeNode);
return TRUE;
}
return _insert_node_into_tree(ppTreeNode, data, NULL);
}
上面的代码已经考虑了不是根节点的情况。我们可以据此添加一个测试用例。
static void test3()
{
TREE_NODE* pTreeNode = NULL;
assert(TRUE == insert_node_into_tree(&pTreeNode, 9));
assert(TRUE == insert_node_into_tree(&pTreeNode, 8));
assert(TRUE == insert_node_into_tree(&pTreeNode, 10));
assert(9 == pTreeNode->data);
assert(8 == pTreeNode->left_child->data);
assert(10 == pTreeNode->right_child->data);
free(pTreeNode->left_child);
free(pTreeNode->right_child);
free(pTreeNode);
}
由于上面的代码是递归代码,为了实现代码的健壮性和完毕性,其实我们设计测试用例的时候应该至少包括9个测试用例:
(1) 参数非法
(2) 根节点不存在
(3)根节点存在,但是插入的数据已经存在
(4)根节点存在,插入数据为 9, 8
(5)根节点存在, 插入数据为9, 10
(6)根节点存在,插入数据为9,8, 7
(7)根节点存在,插入数据为9,7,8
(8)根节点存在,插入数据为7,8, 9
(9)根节点存在,插入数据为7,9,8
分享到:
相关推荐
插入操作是指向排序二叉树中添加新的节点。具体步骤如下: 1. **初始化**:从根节点开始比较新插入节点的值与当前节点的值。 2. **比较大小**:如果新插入节点的值小于当前节点,则进入当前节点的左子树;如果新插入...
1. 程序在运行时,可以执行有关排序二叉树的操作:如插入一个元素、删除一个元素、查找一个元素、打印一个元素等。 2. 用递归算法遍历二叉树。 二、设计分析 1. 二叉树是 n(n>=0)个结点的有限集合,它或为空树...
二叉排序树是一种特殊的二叉树,它的每个结点的关键字都大于左子树的关键字,小于右子树的关键字。因此,在插入新的数据元素时,需要确保树的结构仍然满足二叉排序树的性质。 插入算法的步骤可以分为三步: 1. ...
虽然原文中包含了一些乱码和不清晰的部分,但我们可以根据标题、描述以及部分可识别的内容,来总结和扩展关于插入排序和完全二叉树的知识点。 ### 插入排序 插入排序是一种简单直观的排序算法,它的工作原理是通过...
对于排序二叉树,中序遍历会得到节点从小到大的顺序。 3. **后序遍历**(左-右-根):先遍历左子树,然后遍历右子树,最后访问根节点。 在给定的场景中,我们需要找到特定节点的路径。这可以通过以下步骤实现: 1....
数据结构实验资料二叉树的建立和遍历 本课程实验旨在使学生掌握数据结构的基本...* 插入排序、交换排序、选择排序的算法 通过本实验,学生可以掌握数据结构的基本原理和编程方法,提高学生分析问题和解决问题的能力。
二叉排序树结点查找_插入_删除.cpp
本文将详细讲解如何使用JAVA语言来实现二叉排序树(Binary Search Tree,简称BST),包括插入节点、删除节点以及修改节点的操作,并涉及到字符串比较的方法。 首先,我们来理解二叉排序树的基本概念。二叉排序树是...
在IT领域,数据结构是计算机...通过熟练掌握这些基础知识,开发者可以利用二叉树解决实际问题,比如搜索、排序、文件系统管理等。结合图形化工具,还可以直观地展示和分析二叉树结构,这对于理解和调试代码非常有帮助。
在实际应用中,二叉树遍历广泛用于搜索、排序、表达式求值、数据压缩等领域。理解并熟练掌握这四种遍历方法对解决相关问题至关重要。通过实践这些算法,开发者可以更好地理解和操作二叉树结构,从而在编程中更加...
二叉树的应用广泛,包括搜索、排序、文件系统等。在给定的问题中,我们需要计算二叉树的节点数,这是一个基本的操作,对理解二叉树的特性和操作至关重要。 计算二叉树节点数的算法通常是递归的。在C++编程环境中,...
对于含有同样一组结点的表,由于结点插入的先后次序不同,所构成的二叉排序树的形态和深度也可能不同。 而在二叉排序树上进行查找时的平均查找长度和二叉树的形态有关: ①在最坏情况下,二叉排序树是通过把一个...
在计算机科学中,二叉树是一种重要的数据结构,它由节点(或称为结点)组成,每个节点最多有两个子节点,通常分为左子节点和右子节点。在本实验中,我们将关注一种特殊类型的节点——叶子节点,也称为终端节点,它们...
标签“二叉树”表明主题集中在二叉树的理论和操作上,这可能包括二叉树的性质、遍历方法、查找和插入操作、平衡二叉树(如AVL树和红黑树)以及二叉堆等概念。 在处理“二叉树”这个压缩包文件时,可能会包含相关的...
二叉排序树(Binary Sort Tree,BST)是一种特殊的二叉树数据结构,它的每个节点都包含一个键值,且满足以下性质:对于任意节点,其左子树中的所有节点的键值都小于该节点的键值,而右子树中的所有节点的键值都大于...
这样的结构使得二叉树非常适合进行搜索、排序和组织数据。 1. **二叉树的定义**: - 二叉树是一种特殊的树结构,其中每个节点最多有两个子节点,分别被称为左子节点和右子节点。 - 节点可以包含一个值,称为键或...
在计算机科学中,二叉树被广泛用于各种应用,如搜索、排序、表达式解析等。 二叉树的主要操作包括插入、删除、查找等。在“数据结构大作业求二叉树上结点的路径”这个任务中,可能需要实现这些基本操作,并且要能够...
在这个“链表二叉树数据结构实验”中,我们将探讨三种关键的数据结构概念:链表、二叉树以及排序算法,并通过实际应用来加深理解。 首先,链表是一种线性数据结构,其中的元素并不在物理内存中连续存储。每个元素...
二叉树基本操作,包括实现二叉排序树的查找、插入、构造和删除等算法,使用二叉排序树。