文章目录

  • 树和二叉树
      • 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;
}

数据结构--树和二叉树相关推荐

  1. 数据结构——树和二叉树章节思维导图

    数据结构--树和二叉树章节思维导图

  2. 数据结构-树与二叉树-思维导图+小结

    数据结构-树与二叉树-思维导图 1 数据结构-第五章-树与二叉树-思维导图 2 思维导图-补充 3 小结 3.1 知识点小结 3.2 习题小结 1 数据结构-第五章-树与二叉树-思维导图   数据结构 ...

  3. 王道——数据结构——树与二叉树(3)

    系列文章目录 其他章节相关文章 王道--数据结构--栈和队列(1) 本章节其他相关文章 王道--数据结构--树与二叉树(1) 王道--数据结构--树与二叉树(2) 王道--数据结构--树与二叉树(4) ...

  4. 数据结构—树与二叉树

    总第119篇 前言 之前谈到的线性表.栈和队列都是一对一的数据结构,但是现实中也存在很多一对多的数据结构,这篇要写的就是一种一对多的数据结构---树.全文分为如下几部分: 树的一些基本概念 树的存储结 ...

  5. C语言 数据结构 树和二叉树

    树 1.树:是n节点的有限集.树是n(n=>0)个节点的有限集. n=0时成为空树. 在任意一颗非空树中:(1)有且仅有一个称为根的节点:(2)当n>0时,其余节点可分为m(m>0) ...

  6. 数据结构-树,二叉树,森林

    树,二叉树,森林 王卓老师的数据结构课程笔记 树和二叉树 定义 结点之间有分支,具有层次关系 是n个结点的有限集. 若n = 0,称为空树: 若n > 0,则它满足如下两个条件: 有且仅有一个特 ...

  7. 数据结构树、二叉树、完全二叉树、二叉查找树、平衡二叉树、红黑树、B+树

    树.二叉树.平衡二叉树.二叉搜索树 树的前序遍历.中序遍历和后序遍历 树的前序遍历.中序遍历和后续遍历是以遍历时根所在的位置顺序命名的.层次遍历即按层从上至下,从左至右遍历即可. 前序遍历:根-> ...

  8. 数据结构——树与二叉树

    树与二叉树 一.树的定义: 1.定义:树(Tree)是n(n>=0)个节点的有限集,n=0时称为"空树".在任意一棵非空树中: ⒈有且仅有一个特定的称为根(root)的节点. ...

  9. Python数据结构与算法笔记(八):数据结构——树,二叉树和AVL树

    树 class Node:def __init__(self, name, type='dir'):self.name = nameself.type = type #"dir" ...

最新文章

  1. 雇用Java EE开发人员的一些面试问题
  2. Awesomplete 屌爆了
  3. 显示栅格数据的渲染器
  4. 加速AI计算生态构建,华为昇腾布道西安开发者
  5. 二分最大匹配(匈牙利算法+HK算法)
  6. 快速上手使用本地测试工具postman
  7. faster rcnn 计算mAP
  8. linux服务器共享网络设置方法,Windows和linux网络共享 配置网上邻居
  9. 一起来学linux:磁盘与文件系统:
  10. macos U盘引导安装
  11. 纯CSS3写的10个不同的酷炫图片遮罩层效果
  12. 云日记结构bug心得
  13. 十多位IT专家分享他们离不开的实用工具
  14. 涛思数据TDengine启动报错,提示localEp is different from localhost.localdomain:6030
  15. DicomVCL for D6-D2010-Crack
  16. 【UEFI实战】DEBUG
  17. 基于java 的仿QQ聊天工具
  18. 2017年网络流行语TOP20 , 没用过算我输!
  19. vscode代码自动排版对齐的方法
  20. PTA - 数据库合集36

热门文章

  1. Python:CrawlSpiders
  2. Python:Spider
  3. python的服务器、客户端被拒绝访问_python – uWSGI服务器日志…权限被拒绝读取......
  4. 小菜鸟与后台对接接口下来的感受
  5. 吴裕雄 Bootstrap 前端框架开发——Bootstrap 按钮:禁用按钮
  6. .Net Core快速创建Windows服务
  7. 1.磁盘的数据结构包括那些内容?
  8. ORA-00907:缺少右括号
  9. ORB_SLAM2代码阅读(5)——Bundle Adjustment
  10. android 不重新加载,android – 返回Activity而不重新创建(不调用onCreate())