数据结构--树和二叉树

news/2024/9/21 14:35:59

文章目录

  • 树和二叉树
      • 1.树的定义
      • 2.树的逻辑表示
      • 3.树的基本术语:
      • 4.树的性质
      • 5.树的基本运算
    • 二叉树
      • 二叉树的存储结构
      • 二叉树的遍历

树和二叉树

1.树的定义

2.树的逻辑表示

	树形表示法文氏图表示法凹入图表示法括号表示法

请添加图片描述

3.树的基本术语:

	1‘结点的度:某节点的子树个数2’树的度:最大节点度3‘分支结点与叶结点:度数不为0,为0。4’路径和路径长度5‘有序树和无序树6’森林:n个互不相交的树的集合

4.树的性质

1‘树中的所有结点数等于所有节点的度数之和+1
2’度数m的树第i层最多有m^(i-1)个结点
3‘高度为h的m次树最多有(m^h-1)/(m-1)个结点
4’具有n个结点的m次树的最小高度为[log m(n(m-1)+1)].

5.树的基本运算

		见离散数学

二叉树

二叉树是一种重要的树形结构,其结构定义为:二叉树是n(n≥0)个结点的有限集,它或为空树(n=0),或由一个根结点和两棵分别称为根的左子树和右子树的、互不相交的二叉树组成。
既不是满二叉树也不是完全二叉树,则为一般二叉树

在这里插入图片描述

二叉树的存储结构

顺序存储
在这里插入图片描述
链式存储
在这里插入图片描述

二叉树的遍历

前序遍历
中序遍历
后序遍历

void PreOrderTraverse(BiTree T)//二叉树的先序遍历
{if(T==NULL)return ;printf("%c ",T->data);PreOrderTraverse(T->lchild);PreOrderTraverse(T->rchild);
}
void InOrderTraverse(BiTree T)//二叉树的中序遍历
{if(T==NULL)return ;InOrderTraverse(T->lchild);printf("%c ",T->data);InOrderTraverse(T->rchild);
}
void PostOrderTraverse(BiTree T)//后序遍历
{if(T==NULL)return;PostOrderTraverse(T->lchild);PostOrderTraverse(T->rchild);printf("%c ",T->data);
}
#include<stdio.h>
#include<stdlib.h>
typedef struct BiTNode
{char data;struct BiTNode *lchild,*rchild;
}BiTNode,*BiTree;
void PreOrderTraverse(BiTree T)//二叉树的先序遍历
{if(T==NULL)return ;printf("%c ",T->data);PreOrderTraverse(T->lchild);PreOrderTraverse(T->rchild);
}
void InOrderTraverse(BiTree T)//二叉树的中序遍历
{if(T==NULL)return ;InOrderTraverse(T->lchild);printf("%c ",T->data);InOrderTraverse(T->rchild);
}
void PostOrderTraverse(BiTree T)//后序遍历
{if(T==NULL)return;PostOrderTraverse(T->lchild);PostOrderTraverse(T->rchild);printf("%c ",T->data);
}
void CreateBiTree(BiTree *T)
{char ch;scanf("%c",&ch);if(ch=='#')*T=NULL;else{*T=(BiTree  )malloc(sizeof(BiTNode));if(!*T)exit(-1);(*T)->data=ch;CreateBiTree(&(*T)->lchild);CreateBiTree(&(*T)->rchild);}
}
int main()
{BiTree T;CreateBiTree(&T);PreOrderTraverse (T);InOrderTraverse(T);PostOrderTraverse(T);return 0;
}
#include <iostream>
using namespace std;typedef struct Node
{//定义二叉树结构char data;struct Node *lchild,*rchild;
}*BiTree,BiTNode;void CreateBiTree(BiTree &T)
{//先序创建二叉树char ch;cin>>ch;if(ch=='#') T=NULL;else{T=new BiTNode;T->data=ch;CreateBiTree(T->lchild);CreateBiTree(T->rchild);}
}
void InOrderTraverse(BiTree T)
{//中序遍历if(T){InOrderTraverse(T->lchild);cout<<T->data;InOrderTraverse(T->rchild);}
}
void PreOrderTraverse(BiTree T)
{//先序遍历if(T){cout<<T->data;PreOrderTraverse(T->lchild);PreOrderTraverse(T->rchild);}
}
void PostOrderTraverse(BiTree T)
{//后序遍历if(T){PostOrderTraverse(T->lchild);PostOrderTraverse(T->rchild);cout<<T->data;}
}
void Copy(BiTree T,BiTree &NewT)
{//二叉树的复制if(T==NULL){NewT=NULL;return;}else{NewT=new BiTNode;NewT->data=T->data;Copy(T->lchild,NewT->lchild);Copy(T->rchild,NewT->rchild);}
}
int Depth(BiTree T)
{//树的深度if(T==NULL)return 0;else{int m=Depth(T->lchild);int n=Depth(T->rchild);if(m>n) return (m+1);else return (n+1);}
}
int NodeCount(BiTree T)
{//统计二叉树中结点的个数if(T==NULL) return 0;else return NodeCount(T->lchild)+NodeCount(T->rchild)+1;
}
int LeafCount(BiTree T)
{//统计二叉树中叶子结点的个数if(!T) return 0;if(!T->lchild &&!T->rchild){//如果二叉树左子树和右子树皆为空,说明该二叉树根节点为叶子节点,加1.return 1;}else{return LeafCount(T->lchild)+LeafCount(T->rchild);}
}
int Node_1_Count(BiTree T)
{//统计二叉树的度为1的结点个数if(!T) return 0;if((!T->lchild)&&(T->rchild)||(T->lchild)&&(!T->rchild))return 1 + Node_1_Count(T->lchild) + Node_1_Count(T->rchild);elsereturn Node_1_Count(T->lchild) + Node_1_Count(T->rchild);
}
void PrintAllPath(BiTree T, char path[], int pathlen)
{//二叉树中从每个叶子结点到根结点的路径int i;if(T != NULL) {path[pathlen] = T->data; //将当前结点放入路径中if(T->lchild == NULL && T->rchild == NULL) {//叶子结点for(i = pathlen; i >= 0; i--)cout << path[i] << " " ;cout << endl;}else{PrintAllPath(T->lchild, path, pathlen + 1);PrintAllPath(T->rchild, path, pathlen + 1);}}
}
void ExChangeTree(BiTree &T)
{//构造函数,使用递归算法进行左右结点转换BiTree temp;if(T!=NULL){//判断T是否为空,非空进行转换,否则不转换temp=T->lchild;T->lchild=T->rchild;//直接交换节点地址T->rchild=temp;ExChangeTree(T->lchild);ExChangeTree(T->rchild);}
}
void DblOrderTraverse(BiTree T)
{//二叉树的双序遍历if(T){cout<<T->data;DblOrderTraverse(T->lchild);cout<<T->data;//访问两遍DblOrderTraverse(T->rchild);}
}
int main()
{BiTree T;//测试例子AB#CD##E##F#GH###cout<<"先序遍历输入(以#结束):";CreateBiTree(T);cout<<"中序遍历输出:";InOrderTraverse(T);cout<<endl<<"先序遍历输出:";PreOrderTraverse(T);cout<<endl<<"后序遍历输出:";PostOrderTraverse(T);cout<<endl<<"树的深度:"<<Depth(T);cout<<endl<<"结点的个数:"<<NodeCount(T);cout<<endl<<"叶结点的个数:"<<LeafCount(T);cout<<endl<<"度为1的结点个数:"<<Node_1_Count(T);cout<<endl<<"二叉树中从每个叶子结点到根结点的所有路径:"<<endl;char path[256];int pathlen=0;PrintAllPath(T,path,pathlen);////交换二叉树每个结点的左孩子和右孩子BiTree tem=T;//直接复制一颗树,在不改变原树的前提下,对临时树进行交换。ExChangeTree(tem);cout<<"先序遍历输出交换后的结果:";PreOrderTraverse(tem);cout<<endl<<"双序遍历输出:";DblOrderTraverse(T);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pgtn.cn/news/17619.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

使用Keras训练Lenet网络来进行手写数字识别

使用Keras训练Lenet网络来进行手写数字识别 这篇博客将介绍如何使用Keras训练Lenet网络来进行手写数字识别。 LeNet架构是深度学习中的一项开创性工作&#xff0c;演示了如何训练神经网络以端到端的方式识别图像中的对象&#xff08;即不必进行特征提取&#xff0c;网络能够从…

关闭Windows 7中的 Program Compatibility Assistant

感觉微软总喜欢把简单问题复杂化。安装几个小软件也老是弹出这样的对话框&#xff1a; 然后点击“What settings are applied?”&#xff0c;看到帮助中一段&#xff1a; 提示我在组策略里能够关闭这个烦人的程序兼容性助手&#xff0c;却没有明说&#xff0c;故意卖关子呢。那…

数据结构--DFS

文章目录排列数字n皇后问题方法一方法二排列数字 给定一个整数 n&#xff0c;将数字 1∼n 排成一排&#xff0c;将会有很多种排列方法。 现在&#xff0c;按照字典序将所有的排列方法输出。 利用DFS解决全排列问题 dfs 最重要的是搜索顺序。用什么顺序遍历所有方案。 对于全…

使用Python,OpenCV沿着轮廓寻找极值点

使用Python,OpenCV沿着轮廓寻找极值点 这篇博客将介绍如何使用Python,OpenCV沿着轮廓寻找极值点,找到最北、最南、最东和最西(x,y)坐标。虽然这项技能本身并不有用,但它通常被用作更高级计算机视觉应用程序的预处理步骤。这种应用的一个很好的例子是手势识别(hand ges…

图像识别-opencv

文章目录基本处理基本处理 读取图像 存储图像 import cv2 color_imgcv2.imread(test.png) print(color_img.shape)# 读取单通道 gray_imgcv2.imread(test.png,cv2.IMREAD_GRAYSCALE) print(gray_img.shape)#把单通道图像保存后&#xff0c;再读取&#xff0c;仍然是3通道&…

opencv学习笔记(二)

文章目录绘制几何图形获取并修改图像中的像素点算术操作图像的混合绘制几何图形 ‘’’ 1’绘制直线 2‘绘制圆形 3’绘制矩形 4‘向图像中添加文字 5’效果展示 import cv2 import numpy as np import cv2 as cv import matplotlib.pyplot as plt imgnp.zeros((512,512…

使用Python,OpenCV应用EAST文本检测器检测自然场景图像中的文本

使用Python&#xff0c;OpenCV应用EAST文本检测器检测自然场景图像中的文本1. 效果图2. 原理2.1 为什么自然场景文本检测如此具有挑战性&#xff1f;2.2 替代EAST文本检测实现3. 源码3.1 text_detection.py3.2 text_detection_video.py参考这篇博客将介绍如何使用Python&#x…

数据结构--搜索BFS

文章目录广度优先搜索典型例题广度优先搜索 广度优先搜索类似于树的层次遍历过程。它需要借助一个队列来实现。如图2-1-1所示&#xff0c;要想遍历从v0到v6的每一个顶点&#xff0c;我们可以设v0为第一层&#xff0c;v1、v2、v3为第二层&#xff0c;v4、v5为第三层&#xff0c;…