c语言_二叉树的建立以及3种递归
二叉树c语言的实现
二叉树的建立
二叉树的数据结构
typedef struct node
{
int data;
struct node* left;
struct node* right;
/* data */
} Node;简单创建节点

int main() {
Node n1;
Node n2;
Node n3;
Node n4;
n1.data = 5;
n2.data = 6;
n3.data = 7;
n4.data = 8;
//这时候节点没有连接起来 对节点进行连接
n1.left = &n2; //n2是一个数据实体 而left需要是一个指针 取n2的地址拼到n1的左边上去
n1.right = &n3;
n2.left = &n4;
n2.right = NULL; //即使没东西也要 给出NULL
n3.left = NULL;
n3.right = NULL;
n4.left = NULL;
n4.right = NULL;
//创建成功
//先序遍历验证
preorder(&n1);//放入一个指针地址 作为头节点
}通过遍历树来确认是否是一个真正的二叉树
//先序遍历 递归
void preorder(Node* node){
if(node != NULL){
printf("%d\n",node -> data);
preorder(node -> left);
preorder(node -> right);
}
}
输出结果

中序和后续遍历
//中序遍历 递归
void inorder(Node* node){
if(node != NULL){
inorder(node -> left);
printf("%d\n",node -> data);
inorder(node -> right);
}
}
//后序遍历 递归
void postorder(Node* node){
if(node != NULL){
postorder(node -> left);
postorder(node -> right);
printf("%d\n",node -> data);
}
}改写创建树的代码
void createBiTree(BiTree *T)
{
char ch;
scanf ("%c", &ch); //如果是字符型 %c 回车输入 算一个字符,ubutun会一直递归
if (ch == '#')//扩展二叉树,虚结点 == 0
{
*T = NULL;
}
else
{
*T = (BiTree )malloc(sizeof(BiTNode)); //!!! stdlib.h 头文件一定要加!!!
if (!*T)
{
exit(-1); //错误退出
}
(*T)->data = ch; //生成根结点
createBiTree(&((*T)->lchild)); //构造左子树
createBiTree(&((*T)->rchild)); //构造右子树
}
}最终代码
#include <stdio.h>
#include <stdlib.h>
typedef char ElemType; //这里用int 作为树结点的数据
typedef struct BiTNode
{
ElemType data;
struct BiTNode *lchild, *rchild; //左右孩子指针
}BiTNode, *BiTree;
void createBiTree(BiTree *T); //创建树
void preOrderTraverse(BiTree T); //前序遍历
void inOrderTraverse(BiTree T); //中序遍历
void postOrderTraverse(BiTree T); //后序遍历
int main()
{
BiTree T = NULL;
createBiTree(&T);
preOrderTraverse(T);
printf("\n");
inOrderTraverse(T);
printf("\n");
postOrderTraverse(T);
return 0;
}
void createBiTree(BiTree *T)
{
char ch;
scanf ("%c", &ch); //如果是字符型 %c 回车输入 算一个字符,ubutun会一直递归
if (ch == '#')//扩展二叉树,虚结点 == 0
{
*T = NULL;
}
else
{
*T = (BiTree )malloc(sizeof(BiTNode)); //!!! stdlib.h 头文件一定要加!!!
if (!*T)
{
exit(-1); //错误退出
}
(*T)->data = ch; //生成根结点
createBiTree(&((*T)->lchild)); //构造左子树
createBiTree(&((*T)->rchild)); //构造右子树
}
}
void preOrderTraverse(BiTree T)
{
if (NULL == T)
{
return;
}
printf("%c", T->data); //显示结点数据,可以改成其他对结点的操作
preOrderTraverse(T->lchild); //再先序遍历左子树
preOrderTraverse(T->rchild); //最后先序遍历右子树
}
void inOrderTraverse(BiTree T)
{
if (NULL == T)
{
return;
}
inOrderTraverse(T->lchild); //中序遍历左子树
printf("%c", T->data); //显示结点数据,可以改成其他对结点的操作
inOrderTraverse(T->rchild); //最后再中序遍历右子树
}
void postOrderTraverse(BiTree T)
{
if (NULL == T)
{
return;
}
postOrderTraverse(T->lchild); //先后序遍历左子树
postOrderTraverse(T->rchild); //再后序遍历右子树
printf("%c", T->data); //显示结点数据,可以改成其他对结点的操作
}
输入数据
ABDG##H###CE#I##F##
输出数据

c语言_二叉树的建立以及3种递归的更多相关文章
- C语言实现二叉树的建立、遍历以及表达式的计算
实现代码 #include <stdio.h> #include <stdlib.h> #include <malloc.h> #include <ctype ...
- 数据结构_C语言_二叉树先序、中序、后序遍历
# include <stdio.h> # include <stdlib.h> typedef struct BiTreeNode { char data; struct B ...
- C语言_指针和数组的几种访问形式
敲几行代码来看看几种访问的形式~ #include <stdio.h>;int main() { ] = {, , , , , }; //初始化5个元素的一维数组 int *p = arr ...
- python实现二叉树的建立以及遍历(递归前序、中序、后序遍历,队栈前序、中序、后序、层次遍历)
#-*- coding:utf-8 -*- class Node: def __init__(self,data): self.data=data self.lchild=None self.rchi ...
- 一步一步写数据结构(二叉树的建立和遍历,c++)
简述: 二叉树是十分重要的数据结构,主要用来存放数据,并且方便查找等操作,在很多地方有广泛的应用. 二叉树有很多种类,比如线索二叉树,二叉排序树,平衡二叉树等,本文写的是最基础最简单的二叉树. 思路: ...
- C语言二叉树的建立与遍历
二叉树的建立和遍历都要用到递归,先暂时保存一下代码,其中主要是理解递归的思想,其它的就都好理解了.这里是三种遍历方式,其实理解一种,其它的几个就都理解了,就是打印出来的顺序不一样而已.建立和遍历的方式 ...
- 二叉树的建立与遍历(c语言)入门
树其实在本质上就是一对多,链表就是一对一. 二叉树的建立: 这里的代码采用的是最粗暴的创建方法,无实际用处.但初次学习二叉树可以通过这个创建方法更好的理解二叉树. 二叉树的遍历: 遍历在大体上分为递归 ...
- 3.1 C语言_实现AVL平衡二叉树
[序] 上节我们实现了数据结构中最简单的Vector,那么来到第三章,我们需要实现一个Set set的特点是 内部有序且有唯一元素值:同时各种操作的期望操作时间复杂度在O(n·logn): 那么标准的 ...
- 怎样让Oracle支持中文? 语言_地域.字符集
暂时不涉及数据库业务,但是今天入库的时候中文入库报错,考虑可能是字体不支持,留待备用. 来源:Linux社区 作者:robertkun 语言_地域.字符集SIMPLIFIED CHINESE_CHI ...
随机推荐
- Linux常用命令-软件包管理工具-rpm
命令简介 rpm(RPM Package Manager)是一个强大的命令行驱动的软件包管理工具,用来安装.卸载.校验.查询和更新 Linux 系统上的软件包. 语法格式 rpm [OPTION... ...
- 华为云发布桌面IDE-CodeArts
摘要:华为伙伴暨开发者大会2022,发布华为云桌面IDE-CodeArts. 本文分享自华为云社区<华为云发布桌面IDE-CodeArts,让连接更简单.编码更智能>,作者: Huawei ...
- 配置nginx多域名虚拟主机
1.先做域名映射,由于我们使用的是阿里云域名. 登录阿里云控制台-->域名与网站(万网)-->域名-->选择一个域名-->域名解析-->添加记录 配置静态资源下载转发: ...
- Thread和Runnable的区别和匿名内部类方式实现线程的创建
如果一个类继承Thread,则不适合资源共享.但是如果实现了Runable接口的话,则很容易的实现资源共享. 总结:实现Runnable接口比继承Thread类所具有的优势: 1.适合多个相同的程序代 ...
- git的工作原理和git项目创建及克隆
Git基本理论(重要)三个区域Git本地有三个工作区域:工作目录(Working Directory).暂存区(Stage/Index).资源库(Repository或Git Directory).如 ...
- JAVA学习的第一周
这是发表的第一篇博客,关于Java编程的学习体会如下 1.了解Java的产生与发展时机:1995左右出现Java语言,然后Java的最主要的特点是"跨平台".对于跨平台我不太理解, ...
- 简单状压dp的思考 - 最大独立集问题和最大团问题 - 贰
接着上文 题目链接:最大独立集问题 上次说到,一种用状压DP解决任意无向图最大团问题(MCP)的方程是: 注:此处popcountmax代表按照二进制位下1的个数作为关键字比较,即选择二进制位下1的个 ...
- 全网最新的nacos 2.1.0集群多节点部署教程
原文链接:全网最新的nacos 2.1.0集群多节点部署教程-语雀 基本信息 进度整理中 版本 2.1.0 版本发布日期 2022-04-29 git revision number b5845313 ...
- day06 Socket_线程API_线程并发安全
使用多线程实现多客户端连接服务端 流程图 服务端代码改造: package socket; import java.io.BufferedReader; import java.io.IOExcept ...
- 如何验收安卓PCBA主板的质量和性能
. 版本:v0.1 作者:河东西望 日期:2022-7-15 . 目录 1 有哪些情况需要验收? 2 有哪些验收测试? 2.1 主板测试 2.2 工程测试 2.3 性能测试 2.4 压力测试 2.5 ...