热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【数据结构】回顾二叉树

1.为什么会有树?因为当有大量的输入数据时,链表的线性访问时间就显得略长了。而树结构,其大部分操作的运行时间平均为O(logN)。2.树

1.为什么会有树?因为当有大量的输入数据时,链表的线性访问时间就显得略长了。而树结构,其大部分操作的运行时间平均为O(logN)。

2.树的实现并不难,几行代码就搞定了。

struct TreeNode
{Object element;TreeNode *firstChild;TreeNode *nextSibling;
}

3.遍历形式:

// 中序遍历二叉树
void inorder(tree_pointer ptr)
{if(ptr){inorder(ptr->left_child);printf("%d",ptr->data);inorder(ptr->right_child);}
}// 前序遍历二叉树
void preorder(tree_pointer ptr)
{if(ptr){printf("%d",ptr->data);preorder(ptr->left_child);preorder(ptr->right_child);}
}// 后序遍历二叉树
void postorder(tree_pointer ptr)
{if(ptr){postorder(ptr->left_child);postorder(ptr->right_child);printf("%d",ptr->data);}
}

4.迭代的中序遍历

void iter_inorder(tree_pointer node)
{int top=-1;tree_pointer stack[MAX_STACK_SIZE];for(;;){for(;node;node=node->left_child)add(&top,node);node=delete(&top);if(!node)break;printf("%d",node->data);node=node->right_child;}
}

5.二叉树的层序遍历

void level_order(tree_pointer ptr)
{int front=rear=0;tree_pointer queue[MAX_QUEUE_SIZE];if(!ptr)return;addq(front,&rear,ptr);for(;;){ptr=deleteq(&front,rear);if(ptr){printf("%d",ptr->data);if(ptr->left_child)addq(front,&rear,ptr->left_child);if(ptr->right_child)addq(front,&rear,ptr->right_child);}elsebreak;}
}

6.二叉树的复制

tree_pointer copy(tree_pointer original)
{tree_pointer temp;if(original){temp=(tree_pointer) malloc(sizeof(node));if(IS_FULL(temp)){fprintf(stderr,"The memory is full\n");exit(1);}temp->left_child=copy(original->left_child);tmep->right_child=copy(original->right_child);temp->data=original->data;return temp;}return NULL;
}

7.判断二叉树的等价性

int equal(tree_pointer first,tree_pointer second)
{
return ((!first&&!second)||(first && second && (first->data == second->data) && equal(first->left_child,second->left_child) &&equal(first->right_child,second->right_child));
}

8.寻找结点的中序后继

threaded_pointer insucc(threaded_pointer tree)
{threaded_pointer temp;temp=tree->right_child;if(!tree->right_thread)while(!temp->left_thread)temp=temp->left_child;return temp;
}

9.线索二叉树的中序遍历

void tinorder(threaded_pointer tree)
{threaded_pointer temp=tree;for(;;){temp=insucc(temp);if(temp==tree)break;printf("%3c",temp->data);}
}

10.线索二叉树的右插入操作

void insert_right(threaded_pointer parent,threaded_pointer child)
{threaded_pointer temp;child->right_child=parent->right_child;child->right_thread=parent->right_thread;child->left_child=parent;child->left_thread=TRUE;parent->right_child=child;parent->right_thread=FALSE;if(!child->right_thread){temp=insucc(child);temp->left_child=child;}
}





感谢您的访问,希望对您有所帮助。

欢迎大家关注或收藏、评论或点赞。



为使本文得到斧正和提问,转载请注明出处:
http://blog.csdn.net/nomasp




推荐阅读
  • 深入了解 Windows 窗体中的 SplitContainer 控件
    SplitContainer 控件是 Windows 窗体中的一种复合控件,由两个可调整大小的面板和一个可移动的拆分条组成。本文将详细介绍其功能、属性以及如何通过编程方式创建复杂的用户界面。 ... [详细]
  • 本文深入探讨了二叉搜索树(Binary Search Tree, BST)及其操作,包括查找、插入和删除节点。同时,文章还介绍了平衡二叉树(AVL树)的概念及调整方法,并详细讨论了如何判断两个序列是否构成相同的二叉搜索树。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • 本文深入探讨了C++对象模型中的一些细节问题,特别是虚拟继承和析构函数的处理。通过具体代码示例和详细分析,揭示了书中某些观点的不足之处,并提供了更合理的解释。 ... [详细]
  • 本文探讨了如何通过最小生成树(MST)来计算严格次小生成树。在处理过程中,需特别注意所有边权重相等的情况,以避免错误。我们首先构建最小生成树,然后枚举每条非树边,检查其是否能形成更优的次小生成树。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍了如何在 Windows 环境下使用 node-gyp 工具进行 Node.js 本地扩展的编译和配置,涵盖从环境搭建到代码实现的全过程。 ... [详细]
  • 在 Flutter 开发过程中,开发者经常会遇到 Widget 构造函数中的可选参数 Key。对于初学者来说,理解 Key 的作用和使用场景可能是一个挑战。本文将详细探讨 Key 的概念及其应用场景,并通过实例帮助你更好地掌握这一重要工具。 ... [详细]
author-avatar
用户k3fe6y3kps
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有