遍历二叉树
来源:互联网 发布:被猎头找到 知乎 编辑:程序博客网 时间:2024/06/06 07:21
#include<stdio.h>
typedef struct Node
{
char data;
struct Node * LChild;
struct Node * RChild;
}BiTNode,*BiTree;
//先序遍历创建二叉链表
void CreateBiTree(BiTree *bt)
{
char ch = getchar();
if(ch == '.')
*bt = NULL;
else
{
*bt = (BiTree)malloc(sizeof(BiTNode));
(*bt)->data=ch;
CreateBiTree(&((*bt)->LChild));
CreateBiTree(&((*bt)->RChild));
}
}
//先序遍历二叉树
void PerOrder(BiTree root)
{
if(root!=NULL)
{
print("%c",root->data);
PreOrder(root -> LChild);
PerOrder(root -> RChild);
}
}
//中序遍历二叉树
void InOrder(BiTree root)
{
if(root!=NULL)
{
InOrder(root->LChild);
print("%c",root->data);
InOrder(root->RChild);
}
}
//后续遍历二叉树
void PostOrder(BiTree root)
{
if(root!=NULL)
{
PostOrder(root->LChild);
PostOrder(root->RChild);
print("%c",root->data);
}
}
//输出二叉树中的叶子节点
void LPreOrder(BiTree root)
{
if(root!=NULL)
{
if(root->LChild==NULL && root->RChild==NULL)
print(root->data);
PreOrder(root->LChild);
PreOrder(root->RChild);
}
}
//统计叶子节点
void leaf(BiTree root)
{
int LeafCount = 0;
if(root!=NULL)
{
leaf(root->LChild);
leaf(root->RChild);
if(root->LChild==NULL && root->RChild==NULL)
LeafCount++;
}
}
//先序遍历二叉树高度递归算法
void PreTreeDepth(BiTree bt,int h)
{
int depth = 0;
if(bt!=NULL)
{
if(h>depth)
depth = h;
PreTreeDepth(bt->LChild,h+1);
PreTreeDepth(bt->RChild,h+1);
}
}
int main()
{
int Case = 10;
while(Case--)
{
BiTree tree;
CreateBiTree(&tree);
printf("PerOrder:\n");
PerOrder(tree);
printf("\nInOrder:\n");
InOrder(tree);
printf("\nPostOrder:\n");
PostOrder(tree);
printf("\nPreTreeDepth:\n");
char ch = getChar();
}
return 0;
}
typedef struct Node
{
char data;
struct Node * LChild;
struct Node * RChild;
}BiTNode,*BiTree;
//先序遍历创建二叉链表
void CreateBiTree(BiTree *bt)
{
char ch = getchar();
if(ch == '.')
*bt = NULL;
else
{
*bt = (BiTree)malloc(sizeof(BiTNode));
(*bt)->data=ch;
CreateBiTree(&((*bt)->LChild));
CreateBiTree(&((*bt)->RChild));
}
}
//先序遍历二叉树
void PerOrder(BiTree root)
{
if(root!=NULL)
{
print("%c",root->data);
PreOrder(root -> LChild);
PerOrder(root -> RChild);
}
}
//中序遍历二叉树
void InOrder(BiTree root)
{
if(root!=NULL)
{
InOrder(root->LChild);
print("%c",root->data);
InOrder(root->RChild);
}
}
//后续遍历二叉树
void PostOrder(BiTree root)
{
if(root!=NULL)
{
PostOrder(root->LChild);
PostOrder(root->RChild);
print("%c",root->data);
}
}
//输出二叉树中的叶子节点
void LPreOrder(BiTree root)
{
if(root!=NULL)
{
if(root->LChild==NULL && root->RChild==NULL)
print(root->data);
PreOrder(root->LChild);
PreOrder(root->RChild);
}
}
//统计叶子节点
void leaf(BiTree root)
{
int LeafCount = 0;
if(root!=NULL)
{
leaf(root->LChild);
leaf(root->RChild);
if(root->LChild==NULL && root->RChild==NULL)
LeafCount++;
}
}
//先序遍历二叉树高度递归算法
void PreTreeDepth(BiTree bt,int h)
{
int depth = 0;
if(bt!=NULL)
{
if(h>depth)
depth = h;
PreTreeDepth(bt->LChild,h+1);
PreTreeDepth(bt->RChild,h+1);
}
}
int main()
{
int Case = 10;
while(Case--)
{
BiTree tree;
CreateBiTree(&tree);
printf("PerOrder:\n");
PerOrder(tree);
printf("\nInOrder:\n");
InOrder(tree);
printf("\nPostOrder:\n");
PostOrder(tree);
printf("\nPreTreeDepth:\n");
char ch = getChar();
}
return 0;
}
阅读全文
0 0
- 二叉树遍历、分层遍历
- 遍历二叉树--二叉树
- 【树】遍历二叉树
- 二叉树遍历
- 二叉树遍历
- 二叉树的遍历
- (原创)遍历二叉树
- 二叉树遍历-php
- 查找--遍历二叉树
- 遍历二叉树
- 二叉树遍历规则
- 二叉树的遍历
- 二叉树遍历
- 遍历二叉树
- 二叉树遍历问题
- 二叉树遍历
- 二叉树遍历(zz)
- 二叉树的遍历
- 安装nodejs提示2502处理方法
- 安装CocoaPods最简单教程三步走
- 使用js得到当前页面的url信息方法
- 页面批量新增
- cxDateEdit的格式问题
- 遍历二叉树
- 人工智能领域的几个的技术大牛博客
- 安装Docker Compose
- 2017hdu新生赛 1006 稿件整理
- Struts2基本的执行过程
- MissingResourceException: Can't find resource for bundle java....错误解决
- Android:SwipeRefreshView嵌套DockingExpandableListView 悬停标题外加上拉刷新下拉加载
- iOS 内存管理规则中的例外
- D3.js学习中总结的那些金句