基本                                                                             

结点的度:结点拥有的子树的数目。

叶子:度为零的结点。

分支结点:度不为零的结点。

树的度:树中结点的最大的度。

层次:根结点的层次为1,其余结点的层次等于该结点的双亲结点的层次加1。

树的高度:树中结点的最大层次。

无序树:如果树中结点的各子树之间的次序是不重要的,可以交换位置。

有序树:如果树中结点的各子树之间的次序是重要的, 不可以交换位置。

森林:0个或多个不相交的树组成。对森林加上一个根,森林即成为树;删去根,树即成为森林。

性质                                                                        

1:二叉树第i层上的结点数目最多为 2{i-1} (i≥1)。

2:深度为k的二叉树至多有2{k}-1个结点(k≥1)。

3:包含n个结点的二叉树的高度至少为log2 (n+1)。

4:在任意一棵二叉树中,若终端结点的个数为n0,度为2的结点数为n2,则n0=n2+1。

C实现                                                                      

用先序序列创建一棵二叉树,并且输出字符D位于二叉树的层数。

#include "stdio.h"
#include "stdlib.h"typedef struct BiTNode{char data;   /*结点的数据域*/struct BiTNode *lchild , *rchild;  /*指向左孩子和右孩子*/
} BiTNode , *BiTree;
/*创建一棵二叉树*/
void CreatBiTree(BiTree *T){char c;scanf("%c",&c);if(c == ' ') *T = NULL;else{*T = (BiTNode * )malloc(sizeof(BiTNode));  /*创建根结点*/(*T)->data = c;    /*向根结点中输入数据*/CreatBiTree(&((*T)->lchild));  /*递归地创建左子树*/CreatBiTree(&((*T)->rchild));  /*递归地创建右子树*/}
}
/*访问二叉树结点,输出包含D字符结点位于二叉树中的层数*/
void visit(char c,int level){if(c == 'D')printf("%c is at %d lever of BiTree\n",c,level);
}
/*遍历二叉树*/
void PreOrderTraverse(BiTree T,int level){if(T){   /*递归结束条件,T为空*/visit(T->data,level);  /*访问根结点*/PreOrderTraverse(T->lchild,level+1);  /*先序遍历T的左子树*/PreOrderTraverse(T->rchild,level+1);  /*先序遍历T的右子数*/}
}void main()
{int level = 1;BiTree T = NULL;  /*最开始T指向空*/CreatBiTree(&T);  /*创建二叉树*/PreOrderTraverse(T,level); /*遍历二叉树,找到包含D字符结点位于二叉树中的层数*/
}
本文转自我爱物联网博客园博客,原文链接:http://www.cnblogs.com/yydcdut/p/3678697.html如需转载请自行联系原作者

妙趣横生的算法--二叉树相关推荐

  1. c语言常用算法pdf,妙趣横生的算法(C语言实现 第2版) 带目录完整pdf[94MB]

    <妙趣横生的算法(C语言实现 第2版)>是深受广大读者好评的<妙趣横生的算法(C语言实现)>一书的全新升级版.本书在第1版的基础上对原书内容做了大量的调整和补充,并将书中的实例 ...

  2. 妙趣横生的算法(c语言实现),妙趣横生的算法(C++语言实现) 带目录完整pdf[4MB]

    <妙趣横生的算法(C++语言实现)>内容丰富,生动有趣,寓教于乐,旨在帮助读者学习数据结构和算法的相关知识,从而开阔眼界,培养编程兴趣,提高编程能力,增强求职的竞争力.如果您想提高自己对算 ...

  3. 数据结构与算法--二叉树第k个大的节点

    二叉树第k个大的节点 二叉树文章列表: 数据结构与算法–面试必问AVL树原理及实现 数据结构与算法–二叉树的深度问题 数据结构与算法–二叉堆(最大堆,最小堆)实现及原理 数据结构与算法–二叉查找树转顺 ...

  4. 数据结构与算法-- 二叉树中和为某一值的路径

    二叉树中和为某一值的路径 题目:输入一颗二叉树和一个整数,打印出二叉树中节点值的和为给定值的所有路径.从树的根节点开始往下一只到叶子节点所经过的节点形成一条路径. 我们用二叉树节点的定义沿用之前文章中 ...

  5. 数据结构与算法-- 二叉树后续遍历序列校验

    二叉树后续遍历序列校验 题目:输入一个整数数组,判断改数组是否是某个二叉搜索树的后续遍历结果,如果是返回true否则false,假设输入数组的任意两个数字不相同. 例如输入{5,7,6,9,11,10 ...

  6. javascript数据结构与算法--二叉树遍历(中序)

    javascript数据结构与算法--二叉树遍历(中序) 中序遍历按照节点上的键值,以升序访问BST上的所有节点 代码如下: /**二叉树中,相对较小的值保存在左节点上,较大的值保存在右节点中*** ...

  7. 算法-二叉树:合并两颗二叉树

    算法-二叉树:合并两颗二叉树 思路解析: 使用t1和t2节点同时遍历两棵树,将两颗树的每个根节点相加: 如果t1为空,那么合并之后就是t2: 如果t2为空,那么合并之后就是t1. 方法一:采用递归,下 ...

  8. 数据结构视频教程 -《妙趣横生的算法(C语言实现)》

    整个视频打包下载地址:史上最全的数据结构视频教程系列分享之<妙趣横生的算法(C语言实现)>,转载请保留出处和链接! 更多优秀资源请访问:我是码农 本教程是<妙趣横生的算法(C语言实现 ...

  9. 《妙趣横生的算法(C语言实现)》随书光盘

    本教程是<妙趣横生的算法(C语言实现)>随书光盘的视频教程,理论与实践相结合,旨在帮助学习者理解算法,并提高C语言编程能力,培养读者的编程兴趣,并巩固已有的C语言知识.视频内容涵盖了编程必 ...

最新文章

  1. CSS/font-size和line-height属性继承的研究
  2. 关联关系和依赖关系的区别
  3. 再会迪杰斯特拉(Dijkstra)
  4. Effective Java~58. for-each 循环优先于传统的for 循环
  5. NDPIC极简昼夜瀑布流图片WordPress主题
  6. 英特尔傲腾存储业务主管已离职 因个人原因离开
  7. 二叉搜索树判定方法(c++实现)
  8. C++ 任意进制相互转换
  9. 菜鸟涂鸦作品展_No.24
  10. sql server哪个版本比较好用_给视频加音乐的软件哪个比较好用?
  11. STM32烧写程序:ST-link驱动下载和安装
  12. DOSBOX 0.74模拟器安装Windows 95
  13. html实现圆形图片
  14. nginx reopen nginx 日志
  15. RocketMQ读写队列
  16. mysql利用cpu率高_MySQL CPU 使用率高的原因和解决方法
  17. C1认证学习笔记(第四章)
  18. 问题 G:[ECUST2018新生赛]花梨露营
  19. 实战:吃货联盟和幸运大转盘
  20. 十年Windows铁粉,如今投向Linux的怀抱是为哪般?

热门文章

  1. ES6 知识点及常考面试题
  2. 计算机网络「二」—— 物理层(多图详解)
  3. java堆排序解决topk问题,详解堆排序解决TopK问题
  4. php smarty php函数,smarty中使用php函数的方法
  5. 动态规划之-最大子段和
  6. MyBatis复习(六):MyBatis二级缓存
  7. mysql5.6下载linux云盘,mysql for linux
  8. php mysql foreach_php foreach输出两次
  9. centos 使用mysql_Centos下MySQL使用总结
  10. CDH spark2切换成anaconda3的问题