`
fsplove520
  • 浏览: 27797 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

排序二叉树节点插入

 
阅读更多
二叉树的节点插入比较简单。一般来说,二叉树的插入主要分为以下两个步骤:
    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. **比较大小**:如果新插入节点的值小于当前节点,则进入当前节点的左子树;如果新插入...

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

    1. 程序在运行时,可以执行有关排序二叉树的操作:如插入一个元素、删除一个元素、查找一个元素、打印一个元素等。 2. 用递归算法遍历二叉树。 二、设计分析 1. 二叉树是 n(n&gt;=0)个结点的有限集合,它或为空树...

    二叉排序树插入

    二叉排序树是一种特殊的二叉树,它的每个结点的关键字都大于左子树的关键字,小于右子树的关键字。因此,在插入新的数据元素时,需要确保树的结构仍然满足二叉排序树的性质。 插入算法的步骤可以分为三步: 1. ...

    插入排序与完全二叉树

    虽然原文中包含了一些乱码和不清晰的部分,但我们可以根据标题、描述以及部分可识别的内容,来总结和扩展关于插入排序和完全二叉树的知识点。 ### 插入排序 插入排序是一种简单直观的排序算法,它的工作原理是通过...

    数据结构二叉树上结点的路径

    对于排序二叉树,中序遍历会得到节点从小到大的顺序。 3. **后序遍历**(左-右-根):先遍历左子树,然后遍历右子树,最后访问根节点。 在给定的场景中,我们需要找到特定节点的路径。这可以通过以下步骤实现: 1....

    数据结构实验资料 二叉树的建立和遍历

    数据结构实验资料二叉树的建立和遍历 本课程实验旨在使学生掌握数据结构的基本...* 插入排序、交换排序、选择排序的算法 通过本实验,学生可以掌握数据结构的基本原理和编程方法,提高学生分析问题和解决问题的能力。

    二叉排序树结点查找_插入_删除.cpp

    二叉排序树结点查找_插入_删除.cpp

    JAVA二叉树插入节点、删除节点、修改节点操作(有源码)

    本文将详细讲解如何使用JAVA语言来实现二叉排序树(Binary Search Tree,简称BST),包括插入节点、删除节点以及修改节点的操作,并涉及到字符串比较的方法。 首先,我们来理解二叉排序树的基本概念。二叉排序树是...

    数据结构 C语言建立二叉树

    在IT领域,数据结构是计算机...通过熟练掌握这些基础知识,开发者可以利用二叉树解决实际问题,比如搜索、排序、文件系统管理等。结合图形化工具,还可以直观地展示和分析二叉树结构,这对于理解和调试代码非常有帮助。

    二叉树遍历-前序中序后序层次遍历

    在实际应用中,二叉树遍历广泛用于搜索、排序、表达式求值、数据压缩等领域。理解并熟练掌握这四种遍历方法对解决相关问题至关重要。通过实践这些算法,开发者可以更好地理解和操作二叉树结构,从而在编程中更加...

    计算二叉树的节点数 C++

    二叉树的应用广泛,包括搜索、排序、文件系统等。在给定的问题中,我们需要计算二叉树的节点数,这是一个基本的操作,对理解二叉树的特性和操作至关重要。 计算二叉树节点数的算法通常是递归的。在C++编程环境中,...

    二叉排序树与平衡二叉树的实现

    对于含有同样一组结点的表,由于结点插入的先后次序不同,所构成的二叉排序树的形态和深度也可能不同。 而在二叉排序树上进行查找时的平均查找长度和二叉树的形态有关: ①在最坏情况下,二叉排序树是通过把一个...

    用C语言求二叉树叶子结点

    在计算机科学中,二叉树是一种重要的数据结构,它由节点(或称为结点)组成,每个节点最多有两个子节点,通常分为左子节点和右子节点。在本实验中,我们将关注一种特殊类型的节点——叶子节点,也称为终端节点,它们...

    二叉树交换左右子树 查询祖先结点

    标签“二叉树”表明主题集中在二叉树的理论和操作上,这可能包括二叉树的性质、遍历方法、查找和插入操作、平衡二叉树(如AVL树和红黑树)以及二叉堆等概念。 在处理“二叉树”这个压缩包文件时,可能会包含相关的...

    二叉排序数和平衡二叉树

    二叉排序树(Binary Sort Tree,BST)是一种特殊的二叉树数据结构,它的每个节点都包含一个键值,且满足以下性质:对于任意节点,其左子树中的所有节点的键值都小于该节点的键值,而右子树中的所有节点的键值都大于...

    二叉树

    这样的结构使得二叉树非常适合进行搜索、排序和组织数据。 1. **二叉树的定义**: - 二叉树是一种特殊的树结构,其中每个节点最多有两个子节点,分别被称为左子节点和右子节点。 - 节点可以包含一个值,称为键或...

    数据结构大作业求二叉树上结点的路径.zip

    在计算机科学中,二叉树被广泛用于各种应用,如搜索、排序、表达式解析等。 二叉树的主要操作包括插入、删除、查找等。在“数据结构大作业求二叉树上结点的路径”这个任务中,可能需要实现这些基本操作,并且要能够...

    链表二叉树数据结构实验

    在这个“链表二叉树数据结构实验”中,我们将探讨三种关键的数据结构概念:链表、二叉树以及排序算法,并通过实际应用来加深理解。 首先,链表是一种线性数据结构,其中的元素并不在物理内存中连续存储。每个元素...

    二叉排序树

    二叉树基本操作,包括实现二叉排序树的查找、插入、构造和删除等算法,使用二叉排序树。

Global site tag (gtag.js) - Google Analytics