数据结构:树/二叉树

一、树的概念

逻辑结构:层次结构,一对多

  1. 节点:树中的一个数据元素
  2. 根节点:树中的第一个节点,没有父节点
  3. 孩子节点:该节点的直接下级节点
  4. 父(亲)节点:该结点的直接上级节点
  5. 兄弟节点:有相同父亲节点的
  6. 祖先节点:该结点的间接上级节点
  7. 子孙节点:该结点的间接下级节点
  8. 堂兄弟节点:有相同的祖先节点,在树的同一层的节点
  9. 树的深度:取树中层次的最大值
  10. 节点的度:子节点的个数/分支个数
  11. 树的度:节点度的最大值
  12. 森林:多个树(大于等于2)
  13. 节点的深度:从根节点开始向下的层次

二、 二叉树

节点的度最大为2

严格区分左右子树

1.二叉树的概念

  1. 二叉树的度:最大为2
  2. 左子树:节点左侧的子树
  3. 右子树:节点右侧的子树
  4. 满二叉树:除了叶子节点外,每一个节点的度都为0,叶子节点只能在最后一层
  5. 叶子节点:度为0的节点
  6. 完全二叉树:可以由满二叉树从右侧删除子树得到

2.二叉树的五种形态

3.二叉树的性质

第n层上最多有**:2^(n-1)**

前n层上:2^n-1

二叉树的总节点数:总度数+1 (其中+1,加的是头节点)

4.二叉树的遍历

先序:根左右

中序:左根右

后序:左右根

练习1(一只一棵树的中序遍历和其他两种中任意一种,即可画唯一的二叉树)

先序:ABDGHCEFI 中序:GDHBAECIF

练习2.

中序遍历:HDMIBJNEAFKCG 后序遍历:HMIDNJEBKFGCA

三、功能

二叉树的结构体

cs 复制代码
#ifndef __TREE_H__
#define __TREE_H__
#include <stdio.h>
#include <stdlib.h>

typedef struct tree_node{
	char data;
	struct tree_node *lchild;//左孩子
	struct tree_node *rchild;//右孩子
}tree,*tree_p;


//创建节点的函数
tree_p creat_node(char data);
//创建二叉树(创建节点,再创建节点的左右子树)
//二叉树的左右子树,仍然是一个二叉树
tree_p creat_tree();
//先序遍历:根左右
void pri(tree_p T);
//中序遍历:左根右
void zx(tree_p T);
//后序遍历:左右根
void hx(tree_p T);

#endif

1.创建节点

cs 复制代码
//创建节点的函数
tree_p creat_node(char data){
	tree_p new=(tree_p)malloc(sizeof(tree));
	if(new==NULL){
		printf("申请空间失败\n");
		return NULL;
	}
	new->data=data;
	return new;
}

2.创建二叉树

cs 复制代码
//创建二叉树(创建节点,再创建节点的左右子树)
//二叉树的左右子树,仍然是一个二叉树
tree_p creat_tree(){
	char data='\0'; //定义一个char类型的变量初始化为'\0'
	//不然data就是一个随机值,防止随机为#
	scanf("%c",&data);
	getchar();//吸收垃圾字符
	if(data=='#'){  //#为停止字符
		return NULL;
	}
	tree_p T=creat_node(data);//创建根节点
	T->lchild=creat_tree();  //左子数仍然是一个子树
	T->rchild=creat_tree();
	return T;
}

3.先序遍历

cs 复制代码
//先序遍历:根左右
void pri(tree_p T){
	if(T==NULL){
		return;
	}
	printf("%c->",T->data);
	pri(T->lchild);//给根节点的左孩子调用先序遍历
	pri(T->rchild);//给根节点的右孩子调用先序遍历
}

4.中序遍历

cs 复制代码
//中序遍历:左根右
void zx(tree_p T){
		if(T==NULL){
		return;
	}
		zx(T->lchild);
		printf("%c->",T->data);
		zx(T->rchild);
}

5.后序遍历

cs 复制代码
//后序遍历:左右根
void hx(tree_p T){
	if(T==NULL){
		return;
	}
	hx(T->lchild);
	hx(T->rchild);
	printf("%c->",T->data);
}
相关推荐
小许学java1 小时前
数据结构-模拟实现顺序表和链表
java·数据结构·链表·arraylist·linkedlist·顺序表模拟实现·链表的模拟实现
稚辉君.MCA_P8_Java3 小时前
Gemini永久会员 C++返回最长有效子串长度
开发语言·数据结构·c++·后端·算法
dragoooon344 小时前
[优选算法专题十.哈希表 ——NO.55~57 两数之和、判定是否互为字符重排、存在重复元素]
数据结构·散列表
稚辉君.MCA_P8_Java5 小时前
Gemini永久会员 go数组中最大异或值
数据结构·后端·算法·golang·哈希算法
会员果汁5 小时前
双向链式队列-C语言
c语言·数据结构
AI科技星6 小时前
张祥前统一场论:引力场与磁矢势的关联,反引力场生成及拉格朗日点解析(网友问题解答)
开发语言·数据结构·经验分享·线性代数·算法
C雨后彩虹6 小时前
最少交换次数
java·数据结构·算法·华为·面试
-森屿安年-6 小时前
二叉平衡树的实现
开发语言·数据结构·c++
稚辉君.MCA_P8_Java6 小时前
Gemini永久会员 Go 返回最长有效子串长度
数据结构·后端·算法·golang
TL滕6 小时前
从0开始学算法——第五天(初级排序算法)
数据结构·笔记·学习·算法·排序算法