树和图是数据结构中比较麻烦的东西,里面涉及的概念比较多,也最有用, 就比如一般树广泛应用于人工智能的博弈上,而基于图的广度优先和深度优先搜索也广泛应用于人工智能寻路上面

首先我们要把树进行分类:

>一般树:任意节点子节点个数不限

>二叉树:任意节点子节点个数大于等于0,小于等于2,也即是说0<=n<=2

>森林:N个不相交的树的集合

在讲下面之前你有必要搞懂一些概念,这里我引入一张图片并试图说明这些概念:

根:我们习惯吧最上面的A节点表示为root(根),这个概念可以与生活联系,只不过这里的根是在最上面,

深度:也就是树的层数,比如上图有4层,所以深度为4

节点,就是每一个矩形,树是由节点组成的,因此根也叫做根节点

子节点/孩纸:就是一个节点的下面离它最近的的节点,比如A的子节点是BC而不是BCDEFG,E的子节点是G,G没有子节点

父节点/父亲:这里就是倒置了一下,比如G的父节点是E,EF的父节点是C,BC的父节点是A

堂兄弟:D的堂兄弟是EF

根据上面的概念和上面对树的定义你应该知道这是一个二叉树。

由于二叉树的广泛应用与研究,所以这里我们讨论二叉树,其实森林和一般树都可以转化为一个一般树,转换原则就是把一个节点的第一个子节点变成二叉树的左节点,然后其他堂兄弟就是右节点,这句话不指望你能看懂,因为我都感觉没有表述清楚,我认为这个视频讲得比较好http://pan.baidu.com/s/1i3yYd2t

然后我们再细分二叉树,它分为:

空二叉树:就是什么都没有

满二叉树:每个节点都有两个子节点

完全二叉树:把一颗完全二叉树的最后一层从右往左删除一些节点得到的就是完全二叉树

二叉树也分顺序存储和链式存储,因为顺序存储比较浪费内存,所以这里考虑用链式存储实现

struct node{
	char data;
	struct node *lchild;
	struct node *rchild;
};

这样我们就定义了一个简单的二叉树节点,它包含一个数据域和两个指针域,两个指针域分别用来指向左孩纸(左节点)和右孩纸(右节点),然后再看看这图,我们接下来将定义一个如图所示的二叉树:


struct node *create_binary_tree(){
	struct node *root;
	struct node *a=new node,*b=new node,*c=new node,*d=new node,*e=new node,*f=new node,*g=new node;
	a->data='A';
	b->data='B';
	c->data='C';
	d->data='D';
	e->data='E';
	f->data='F';
	g->data='G';
	a->lchild=b;
	a->rchild=c;
	b->lchild=d;
	b->rchild=NULL;
	c->lchild=e;
	c->rchild=f;
	d->lchild=NULL;
	d->rchild=NULL;
	e->lchild=g;
	e->rchild=NULL;
	f->lchild=NULL;
	f->rchild=NULL;
	g->lchild=NULL;
	g->rchild=NULL;
	root=a;
	return root;
}

上面代码非常简单,结合上图可以很容易理解

接下来讲的就是重点了:二叉树的遍历

二叉树的遍历分为前序遍历,中序遍历,后序遍历,层序遍历

你得用心才能看懂下面的内容,还是再次建议看一下这个视频http://pan.baidu.com/s/1i3yYd2t

首先讲讲最简单的层序遍历,顾名思义,从上至下一层一层的遍历,所以遍历顺序就是ABCDEFG

然后是前序遍历,前序遍历的原则就是先遍历根节点(注意这里的根节点是相对意义上的),然后再遍历左节点,然后遍历右节点,所以遍历顺序是ABDCEGF

接下来就是中序遍历,中序遍历就是先遍历左节点,然后遍历根,最后右节点,所以遍历顺序就是DBAGECF

最后是后序遍历,后序遍历是先遍历左节点然后右节点最后根,所以遍历顺序是DBGEFCA

这里看似很麻烦,但是如果我们用代码写其实很简单,主要运用了递归的思想,代码如下:

//ABDCEGF前序
void PreTraversal(struct node *root){
	if(root!=NULL){
		std::cout<<root->data;
		PreTraversal(root->lchild);
		PreTraversal(root->rchild);
	}
}
//DBAGECF中序

void InTraversal(struct node *root){
	if(root!=NULL){
		InTraversal(root->lchild);
		std::cout<<root->data;
		InTraversal(root->rchild);
	}
}

void insert(struct node *root){
}

//DBGEFCA后序
void NexTraversal(struct node *root){
	if(root!=NULL){
		NexTraversal(root->lchild);
		NexTraversal(root->rchild);
		std::cout<<root->data;
	}
}

到这里就结束了,我们没有讲动态二叉树的创建,这里提供一份资料以供参考[1]


[数据结构]C语言二叉树的实现的更多相关文章

  1. 深入浅出数据结构C语言版(12)——从二分查找到二叉树

    在很多有关数据结构和算法的书籍或文章中,作者往往是介绍完了什么是树后就直入主题的谈什么是二叉树balabala的.但我今天决定不按这个套路来.我个人觉得,一个东西或者说一种技术存在总该有一定的道理,不 ...

  2. c++学习书籍推荐《清华大学计算机系列教材:数据结构(C++语言版)(第3版)》下载

    百度云及其他网盘下载地址:点我 编辑推荐 <清华大学计算机系列教材:数据结构(C++语言版)(第3版)>习题解析涵盖验证型.拓展型.反思型.实践型和研究型习题,总计290余道大题.525道 ...

  3. javascript数据结构与算法-- 二叉树

    javascript数据结构与算法-- 二叉树 树是计算机科学中经常用到的一种数据结构.树是一种非线性的数据结构,以分成的方式存储数据,树被用来存储具有层级关系的数据,比如文件系统的文件,树还被用来存 ...

  4. SDUT 3346 数据结构实验之二叉树七:叶子问题

    数据结构实验之二叉树七:叶子问题 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 已知一个按 ...

  5. SDUT 3345 数据结构实验之二叉树六:哈夫曼编码

    数据结构实验之二叉树六:哈夫曼编码 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 字符的编 ...

  6. SDUT 3340 数据结构实验之二叉树一:树的同构

    数据结构实验之二叉树一:树的同构 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 给定两棵树 ...

  7. SDUT 3344 数据结构实验之二叉树五:层序遍历

    数据结构实验之二叉树五:层序遍历 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 已知一个按 ...

  8. 【数据结构】之二叉树的java实现

    转自:http://blog.csdn.net/wuwenxiang91322/article/details/12231657 二叉树的定义: 二叉树是树形结构的一个重要类型.许多实际问题抽象出来的 ...

  9. 数据结构C语言版 有向图的十字链表存储表示和实现

    /*1wangxiaobo@163.com 数据结构C语言版 有向图的十字链表存储表示和实现 P165 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h> ...

随机推荐

  1. 基于HTML5 Canvas 点击添加 2D 3D 机柜模型

    今天又返回好好地消化了一下我们的数据容器 DataModel,这里给新手做一个典型的数据模型事件处理的例子作为参考.这个例子看起来很简单,实际上结合了数据模型中非常重要的三个事件处理的部分:属性变化事 ...

  2. 无法将类型为“System.DBNull”的对象强制转换为类型“System.String”

    在ERP中做业务类单据,有时候会遇到这样的报错. 无法将类型为"System.DBNull"的对象强制转换为类型"System.String"   去数据库中检 ...

  3. ecshop根据订单号查询物流信息

    目标:订单详情页可以根据订单查询当前物流信息. 效果图: 思路:点击后异步请求快递查询api,接受返回信息,拼接. 代码: admin下:order_info.htm //一:顶部插入jquery,在 ...

  4. 二维,多维数组排序array_multisort()函数的使用

    对于数组的排序,很很多方法:随便百度了一下 sort() - 以升序对数组排序 rsort() - 以降序对数组排序 asort() - 根据值,以升序对关联数组进行排序 ksort() - 根据键, ...

  5. 分布式监控系统Zabbix3.2跳坑指南

    zabbix是什么在此就不多作介绍了,可以参考之前的文章 零代码如何打造自己的实时监控预警系统 ,这篇主要介绍安装及注意事项. 主要分为服务端和客户端安装,客户端又分为Linux.Windows. 服 ...

  6. cinder块存储控制节点

    #cinder块存储控制节点 openstack pike 安装 目录汇总 http://www.cnblogs.com/elvi/p/7613861.html #cinder块存储控制节点 #在控制 ...

  7. php中使用swoole实现头协议

    当需要有数据交互的时候,为了安全起见,双方会协商一个固定的头协议,这样必须实现其头协议才能拿到数据. PHP的swoole完美的提供了固定包头+包体协议自动分包. 首先需要通过open_length_ ...

  8. Centos7 下安装Docke

    为什么 要用centos7呢. 现在哪个企业用的是centos7呀.不都是老版本么. 对咱们是新技术.所以只有新系统才可以用.因为docker要求服务CentOS6以上,kernel 版本必须2.6. ...

  9. Postgres的tuple的组装

    1.相关的数据类型 我们先看相关的数据类型: HeapTupleData(src/include/access/htup.h) typedef struct HeapTupleData { uint3 ...

  10. C#的数据类型总结(2):decimal ,double,float的区别

    1> 三者是精度不同的浮点数,如下图 参见:https://docs.microsoft.com/zh-cn/dotnet/articles/csharp/language-reference/ ...