二叉树总结——BiTree
在C++编译器下可直接运行
#include <stdio.h>
#include <malloc.h>
//算法思想:先读入根结点数据,并且创建根结点,在读入左子树数据并创建左子树
//之后再读入右子树数据并创建右子树,在根结点左右子树创建好之后,最终将根结点返回。
typedef char ElemType;
typedef struct BiTNode
{
ElemType data;
struct BiTNode *lchild,*rchild;
}BiTNode,*BiTree;
BiTNode *createBiTree()//该函数用来创建一棵树
{
BiTNode *T = NULL;
ElemType enter;
enter = getchar();//可能读入空格,这样就结束输入
if('@' != enter)
{
T = (BiTNode *)malloc(sizeof(BiTNode));
T->data = enter;
T->lchild = createBiTree();//结构体用点,结构体指针用箭头***********
T->rchild = createBiTree();
}
return T;
}
void preOrder(BiTree T)
{
if(T != NULL)
{
printf("%c ", T->data);
preOrder(T->lchild);
preOrder(T->rchild);
}
}
void midOrder(BiTree T)
{
if(T != NULL)
{
midOrder(T->lchild);
printf("%c ", T->data);
midOrder(T->rchild);
}
}
//給定二叉鏈表的先序遍歷和中序遍歷,構造一顆二叉鏈表表示一棵樹
BiTNode *createBiTree1(ElemType preOrderList[],int preStartIndex,int preEndIndex,
ElemType inOrderList[],int inStartIndex,int inEndIndex)
{
if(preStartIndex > preEndIndex)
{
return NULL;
}
BiTNode *t = (BiTNode *)malloc(sizeof(BiTNode));
t->data = preOrderList[preStartIndex];
int rootIndex;
for(rootIndex = inStartIndex;rootIndex <= inEndIndex;rootIndex++)//在中序序列中查找跟節點位置
{
if(t->data == inOrderList[rootIndex])
{
break;
}
}
int length = rootIndex - inStartIndex;
t->lchild = createBiTree1(preOrderList,preStartIndex + 1,preStartIndex + length,
inOrderList,inStartIndex,rootIndex - 1);
t->rchild = createBiTree1(preOrderList,preStartIndex + length + 1,preEndIndex,
inOrderList,rootIndex + 1,inEndIndex);
return t;
}
//层次遍历
//输入层次遍历序列和中序序列创建一棵二叉树
//算法思想:先层次遍历确定(子树)根结点,再到中序序列中确定根位置,分出左右子树数列。
//然后确定层次遍历对左右子树序列,构建左右子树,重复上述步骤,构建整棵二叉树。
#define MAX_SIZE 100
BiTNode *createBiTree2(ElemType levelOrderList[],int levelStartIndex,int levelEndIndex,
ElemType inOrderList[],int inStartIndex,int inEndIndex)
{
if(levelStartIndex > levelEndIndex)
{
return NULL;
}
BiTNode *t = (BiTNode *)malloc(sizeof(BiTNode));
t->data = levelOrderList[levelStartIndex];
int rootIndex;//在中序遍历序列中确定子树根结点位置
for(rootIndex = inStartIndex;rootIndex < inEndIndex;rootIndex++)
{
if(inOrderList[rootIndex] == t->data)
{
break;
}
}
ElemType lftLeverOrderList[MAX_SIZE];
int lftLeverLength = 0;
for(int j = levelStartIndex + 1;j <= levelEndIndex;j++)//找出左子树的层次遍历序列
{
for(int i = inStartIndex;i <= rootIndex - 1;i++)
{
if(inOrderList[i] == levelOrderList[j])
{
lftLeverOrderList[lftLeverLength++] = levelOrderList[j];
}
}
}
ElemType rgtLeverOrderList[MAX_SIZE];
int rgtLeverLength = 0;
for(int j = levelStartIndex + 1;j <= levelEndIndex;j++)//找出左子树的层次遍历序列
{
for(int i = rootIndex + 1;i <= inEndIndex;i++)
{
if(inOrderList[i] == levelOrderList[j])
{
rgtLeverOrderList[rgtLeverLength++] = levelOrderList[j];
}
}
}
t->lchild = createBiTree2(lftLeverOrderList,0,lftLeverLength - 1,
inOrderList,inStartIndex,rootIndex - 1);
t->rchild = createBiTree2(rgtLeverOrderList,0,rgtLeverLength - 1,
inOrderList,rootIndex + 1,inEndIndex);
return t;
}
////层次遍历
//void levelTravelBiTree(BiTree T)
//{
// queue q;
// initailQueue(q);
// enQueue
//}
int main()
{
// BiTree T = createBiTree();
// preOrder(T);
// midOrder(T);
// char preOrderList[] = {'A','B','D','E','C','F','G'};
// int preOrderListLength = 7;
char leverOrderList[] = {'A','B','C','D','E','F','G'};
int leverOrderListLength = 7;
char inOrderList[] = {'D','B','E','A','F','C','G'};
int inOrderListLength = 7;
BiTree t = createBiTree2(leverOrderList,0,leverOrderListLength - 1,inOrderList,0,inOrderListLength - 1);
preOrder(t);
printf("\n");
midOrder(t);
return 0;
}
二叉树总结——BiTree的更多相关文章
- 二叉树根结点到任意结点的路径(C语言)
有一棵二叉树,如下图所示: 其中 # 表示空结点. 先序遍历:A B D E G C F 问题:怎么得到从根结点到任意结点的路径呢? 示例:输入 G,怎么得到从结点 A 到结点 G 的路径呢? 很明显 ...
- Siki_Unity_3-13_编程内功修炼-算法
Unity 3-13 编程内功修炼 -- 算法 任务1&2:课程介绍 主要算法: 分治法 堆排序 二叉树 动态规划 贪心算法 图 任务3:分治算法 -- Divide and Conquer ...
- 数据结构代码整理(线性表,栈,队列,串,二叉树,图的建立和遍历stl,最小生成树prim算法)。。持续更新中。。。
//归并排序递归方法实现 #include <iostream> #include <cstdio> using namespace std; #define maxn 100 ...
- 二叉树的实现与一些基本操作(C++环境)
#include<cstdio>#include<cstdlib>#include<iostream>#include<cstring>using na ...
- 二叉树[C实现]
#include<stdio.h> #include<malloc.h> #include<iostream> //定义节点 typedef struct BiNo ...
- NYOJ-756重建二叉树
重建二叉树 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 题目很简单,给你一棵二叉树的后序和中序序列,求出它的前序序列(So easy!). 输入 输入有多组数据(少于 ...
- 数据结构算法C语言实现(二十)--- 6.3.1遍历二叉树
一.简述 二叉树的遍历主要是先序.中序.后序及对应的递归和非递归算法,共3x2=6种,其中后序非递归在实现上稍复杂一些.二叉树的遍历是理解和学习递归及体会栈的工作原理的绝佳工具! 此外,非递归所用的栈 ...
- 【面经】用递归方法对二叉树进行层次遍历 && 二叉树深度
void PrintNodeAtLevel(BiTree T,int level) { // 空树或层级不合理 ) return; == level) { cout << T->da ...
- 树(二)——二叉树
目录 本章主要讲解内容为: 树的非递归遍历算法,两种版本 树的扩展前缀以及前缀中缀构建方法 源码 btree.cpp btree.h 基础知识 一.定义 二叉树的递归定义:二叉树是每个结点最多含有两棵 ...
- c语言二叉树基本操作
编译器为vs2013 #include "stdafx.h" #include<malloc.h> #include<stdlib.h> #define O ...
随机推荐
- 【设计模式】Java设计模式 -工厂模式
[设计模式]Java设计模式 -工厂模式 不断学习才是王道 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 一个有梦有戏的人 @怒放吧德德 分享学习心得,欢迎指正,大家一起学习成长! 目 ...
- KingbaseES触发器介绍
触发器及其作用 触发器(trigger)是用户定义的由事件驱动的特殊过程.一旦定义,所有用户的对应操作均会由服务器自动激活相应的触发器,在DBMS核心层进行集中的完整性控制. 触发器类似于约束,但是比 ...
- 一个注解解决ShardingJdbc不支持复杂SQL
背景介绍 公司最近做分库分表业务,接入了 Sharding JDBC,接入完成后,回归测试时发现好几个 SQL 执行报错,关键这几个表都还不是分片表.报错如下: 这下糟了嘛.熟悉 Sharding J ...
- 配置git环境与项目创建
主要用于记录上课笔记,方便以后复习 acgit的地址:https://git.acwing.com/wyw/kob1/ 1. 项目模块的包含 1.1 采用前后端分离 Web端大概框架 2. git环境 ...
- AQS:Java 中悲观锁的底层实现机制
介绍 AQS AQS(AbstractQueuedSynchronizer)是 Java 并发包中,实现各种同步组件的基础.比如 各种锁:ReentrantLock.ReadWriteLock.Sta ...
- 使用Gitlab CI/CD功能在本地部署 Spring Boot 项目
前提条件: 1.Docker安装Gitlab,地址:https://www.cnblogs.com/sanduzxcvbnm/p/13814730.html 2.Docker安装Gitlab-runn ...
- 使用 Elastic 技术栈构建 K8S 全栈监控 -2: 用 Metricbeat 对 Kubernetes 集群进行监控
文章转载自:https://www.qikqiak.com/post/k8s-monitor-use-elastic-stack-2/ 操作步骤 git clone https://github.co ...
- KVM里安装不是原装的winxp系统镜像
从网上下载的winxp系统镜像,虽然是iso格式的,但是里面的内容是如下情况的 因此安装的话,需要采取如下步骤 1.添加一个光驱引导,挂载一个iso格式的pe 2.再添加一个光驱,挂载iso格式的wi ...
- Tubian0.43,完善对QQ微信的支持
Sourceforge.net下载:https://sourceforge.net/projects/tubian/ 123网盘下载: https://www.123pan.com/s/XjkKVv- ...
- [题解] Atcoder Beginner Contest ABC 265 Ex No-capture Lance Game DP,二维FFT
题目 首先明确先手的棋子是往左走的,将其称为棋子1:后手的棋子是往右走的,将其称为棋子2. 如果有一些行满足1在2右边,也就是面对面,那其实就是一个nim,每一行都是一堆石子,数量是两个棋子之间的空格 ...