二叉树算法

news2025/7/7 7:11:13

写在前面

树的定义

typedef struct Node
{
    int data;
    struct Node *lchild,*rchild;
}Bnode,*Btree;


最近公共祖先

已知一棵二叉树按顺序存储结构进行存储,设计一个算法,求编号分别为i和j的两个节点的最近公共祖先节点的值。

算法思想:

  1. 顺序存储采用数组进行存储。
  2. i的祖先就是i/2
  3. 不断比较i和j的大小,将最大的数取一半,直到i=j,就是找到了最近公共祖先节点。
int FindAncestor(int T[],int i,int j)
{
	if(T[i]!=NULL && T[j]!=NULL)
	{
		while(i!=j)
		{
			if(i>j) i=i/2;
			else  j=j/2;
		}
		return i;
	}
}

二叉树的层次遍历

算法思想:

  1. 用队列将根节点入队
  2. 出队,访问出队节点
  3. 若有左子树,将左子树入队
  4. 若有右子树,将右子树入队
  5. 循环234,直到队列为空
void LevelOrder(Btree T)
{
	InitQueue(Q);
	Btree p;
	EnQueue(Q,T);
	while(!IsEmpty(Q)
	{
		DeQueue(Q,p);
		visit(p);
		if(p->lchild!=NULL)
			EnQueue(Q,p->lchild);
		if(p->rchild!=NULL)
			EnQueue(Q,p->rchild);
	}

二叉树的高度

算法思想:

  1. 后序遍历,递归公式:树高=max(左子树高度, 右子树高度)+1
  2. 非递归:采用层次遍历,用类指针last指向每层最后边节点,用变量level记录层数,last每向下一层level+1
    递归
int Btdepth(Btree T)
{
	if(T==NULL) return 0;
	int l=Btdepth(T->lchild);
	int r=Btdepth(T->rchild);
	return (l>r ? l:r)+1

非递归

int Btdepth_f(Btree T)
{
	if(T==NULL)return 0;
	Btree Q[Maxsize];//队列
	int front=-1,rear=-1;
	int last=0,level=0;//last记录每层最后边节点
	Btree p;
	while(front<rear)
	{
		p=Q[++front];
		if(p->lchild)
			Q[++rear]=p->lchild;
		if(p->rchild]
			Q[++rear]=p->rchild;
		if(front==last)
		{
			level++;
			last=rear;
		}
	}
	return level;
}

二叉树所有左右子树交换

算法思想:

  1. 递归:后序遍历时候交换左右子树(也可前序遍历)
void Bswap(Btree T)
{
	if(T)
	{
		Bswap(T->lchild);
		Bswap(T->rchild);
		Btree temp=T->lchild;
		T->lchild=T->rchild;
		T->rchild=temp;
	}
}

二叉树度为2节点个数

算法思想:

  1. 递归:树双节点=左子树双节点+右子树双节点+1(左右子树都存在)
  2. 树双节点=左子树双节点+右子树双节点(左右有任意不存在)
int DoubleNode(Btree T)
{
	if(T==NULL)return 0;
	if(T->lchild!=NULL && T->rchild!=NULL)
		return DoubleNode(T->lchild)+DoubleNode(T->rchild)+1;
	else
		return DoubleNode(T->lchild)+DoubleNode(T->rchild);
}

二叉树所有节点个数

算法思想:

  1. 递归:节点数=左子树节点+右子树节点+1;
  2. 递归:前中后续遍历
int countT(Btree T)
{
	if(T==NULL)return 0;
	return countT(T->lchild)+countT(T->rchild);
}
int n=0;
void PreOrder(Btree T)
{
	if(p)
	{
		PreOrder(T->lchild);
		PreOrder(T->rchild);
		n++;
	}
}

二叉树所有叶子节点个数

算法思想:

  1. f=左子树叶子节点+右子树叶子节点
int count(Btree T)
{
	if(T==NULL)return 0;
	if(T->lchild==T->rchild==NULL) return 1;
	return count(T->lchild)+count(T->rchild);
}

二叉树值为x节点所在层

算法思想:

  1. 前序遍历,本层结点高h,到左子树h+1,从右子树回到上一层h-1
int h=1;
void Order(Btree T,int x)
{
	if(T)
	{
		if(T->data==x)
			print("%d",h);
		h++;
		Find(T->lchild,x);
		Find(T->rchild,x);
		h--;
	}
}

对称二叉树

判断一个二叉树是否对称。

算法思想:

  1. 后续遍历
int compare(Btree l,Btree r)
{
	//判断本层是否相等
	if(l==NULL && r!=NULL)return 0;//左空,右不空,不等
	if(l!=NULL && r==NULL)return 0;//左不空,右空,不等
	if(l==NULL && r==NULL)return 1;//左空,右空,相等
	if(l->data != r->data)return 0;//左右值不等,不等
	//若相等进入下一层判断
	int outside=compare(l->lchild,r->rchild);//比较当前左节点的左孩子和右节点的右孩子,即为最外层比较
	int inside=compare(l->rchild,r->lchild);//比较当前左节点的右孩子和右节点的左孩子,即为内层比较
	int res=outside*inside;//内外是否同时相等
	return res;
}

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

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

相关文章

牛客竞赛每日俩题 - Day9

目录 日期推算 分解因数 日期推算 美国节日__牛客网 思路&#xff1a; 首先&#xff0c;我们要想找到一个月第N个星期W&#xff0c;一定需要一个参照物&#xff0c;最好的目标当然是这个月的第一天。拿到参照物后&#xff0c;我要能得 到参照物的星期数&#xff0c;然后就能…

马来酰亚胺聚乙二醇叠氮,MAL-PEG-N3,Maleimide-PEG-Azide

马来酰亚胺聚乙二醇叠氮&#xff08;MAL-PEG-N3&#xff09;是MeloPEG的硫醇反应性“点击化学”PEG交联剂之一。马来酰亚胺与pH 6.5-7.5的游离巯基/巯基迅速反应&#xff0c;形成稳定的&#xff0c;不可裂解的硫醚键。马来酰亚胺和硫醇的反应使得叠氮化物功能性PEG能够快速有效…

[附源码]Python计算机毕业设计Django的家政服务平台

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

设计模式-Acyclic Visitor(非循环访问者模式)

目的&#xff1a;允许将新功能添加到现有的类层次结构中&#xff0c;而不会影响这些层次结构&#xff0c;也不会有四人帮访客模式中那样循环依赖的问题。 类图&#xff1a; 使用场景&#xff1a; 需要在现有层次结构中添加新功能而无需更改或影响该层次结构时。 当某些功能在层…

Linux服务器远程访问通过Tomcat部署的静态资源

一、安装Java和Tomcat 1.1 安装Java 下载jdk8切换到root用户&#xff0c;创建文件夹/usr/local/java&#xff0c;将下载的jdk压缩包上传到该目录下&#xff0c;解压 mkdir /usr/local/java cd /usr/local/java rz tar -zxvf jdk-8u351-linux-x64.tar.gz编辑配置文件&#xf…

数据技术篇之数据服务

第6章 数据服务 1.服务架构演进 演进过程 DWSOA &#xff08;1&#xff09;实施原理   将业务方对数据的需求通过SOA服务的方式暴露出去。有需求驱动&#xff0c;一个需求开发一个或则几个接口&#xff0c;编写接口文档&#xff0c;开放给业务方调用。 &#xff08;2&…

[附源码]Python计算机毕业设计SSM基于WEB的心理测评系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

【手把手教你】使用qstock进行量化回测

01qstock简介qstock由“Python金融量化”公众号开发&#xff0c;试图打造成个人量化投研分析开源库&#xff0c;目前包括数据获取&#xff08;data&#xff09;、可视化(plot)、选股(stock)和量化回测&#xff08;backtest&#xff09;四个模块。其中数据模块&#xff08;data&…

SAS中用单因素ANOVA研究不同疗法对焦虑症的有效性

本教程将介绍如何使用SAS进行单因素方差分析。 最近我们被客户要求撰写关于单因素ANOVA的研究报告&#xff0c;包括一些图形和统计输出。我们想研究不同疗法对焦虑症的有效性。我们收集了以下类别的75个主题的样本&#xff1a; 无处理&#xff08;1个n1 27&#xff09;。生物…

5W3H法与SMART原则的结合使用

5W3H 5W3H分析法&#xff0c;又称“八何分析法”。在实际工作中&#xff0c;人们常常运用5W3H分析法&#xff0c;进行顾客分析、市场需求分析&#xff0c;解决计划编制的结构问题、方向问题、执行力问题。 5W3H是描述问题的手段&#xff0c;其具体指的是&#xff1a;What&…

【图像处理】深入解析LBP算法

问题 LBP是一种常见的特征描述算法&#xff0c;用来提取局部的纹理特征&#xff0c;其原理其实很简单&#xff0c;下面我们就来看看它是怎么一回事吧。 LBP简介 LBP&#xff08;Local Binary Patterns&#xff0c;局部二值模式&#xff09;是一种很简单但很高效的局部纹理特…

2025年DMS前装搭载或突破750万辆!多方势力搅局「融合集成」

在智能驾驶功能和舱内人机交互体验不断融合演进的过程中&#xff0c;基于摄像头的DMS/OMS功能正在进入新的发展周期。而在欧洲等部分国家及地区&#xff0c;DMS的标配&#xff08;主要涉及驾驶安全的监控&#xff0c;比如&#xff0c;驾驶员疲劳、注意力分散、安全带使用、吸烟…

java工厂策略模式的开发应用

java工厂策略模式的开发应用前言准备工作具体实现测试仰天大笑出门去&#xff0c;我辈岂是蓬蒿人前言 大概内容&#xff1a; 假设我有五个车间&#xff0c;每一个车间生产不同的车子&#xff0c;想要统一管理&#xff0c;不关心哪个车间生产什么车&#xff1b;只需找一个代理…

Ajax(一)

1.客户端与服务器 1.1 服务器 上网过程中&#xff0c;负责存放和对外提供资源的电脑。 1.2 客户端 上网过程中&#xff0c;负责获取和消费资源的电脑。 2.URL地址 2.1 URL地址的概念 2.2 URL地址的组成部分 3. 分析网页的打开过程 3.1 图解客户端与服务器的通信过程 三个…

NLP学习笔记(一) RNN基本介绍

大家好&#xff0c;我是半虹&#xff0c;这篇文章来讲循环神经网络 (Recurrent Neural Network, RNN) 文章行文思路如下&#xff1a; 首先通过前馈神经网络引出为啥需要循环神经网络然后介绍循环神经网络的核心思想与运作方式最后拓展两个循环神经网络常见且常用的变体 在讲循…

Windows 7恢复分区丢失了怎么恢复?

问题&#xff1a;Windows 7恢复分区丢失 戴尔、惠普和华硕等电脑制造商现会在他们的计算机上创建一个恢复分区。恢复分区允许用户在系统出现问题时将计算机恢复到出厂默认设置。但是&#xff0c;由于丢失了恢复分区&#xff0c;因此某些用户无法将电脑恢复到出厂设置。这是一个…

析构函数可以为纯虚函数吗?纯虚函数可以有函数体吗?纯虚函数需要函数体吗?

先回答标题中中的几个问题&#xff1a; 析构函数可以为纯虚函数吗&#xff1f; yes。纯虚函数可以有函数体吗&#xff1f; yes。纯虚函数需要函数体吗&#xff1f; 一般来讲&#xff0c;如果析构函数是纯虚函数&#xff0c;那么析构函数必须要有函数体&#xff0c;如果是其它函…

Web前端大作业:基于bootstrap响应式页面,家具装修公司网站

&#x1f389;精彩专栏推荐 &#x1f4ad;文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;毕设项目精品实战案例 (10…

最新版本APT漏洞利用工具箱

点击"仙网攻城狮”关注我们哦~不当想研发的渗透人不是好运维让我们每天进步一点点简介1.最近发现一个好用的渗透工具箱&#xff0c;基本包含最新热门漏洞exp&#xff0c;分享一下项目地址&#xff1a;https://github.com/White-hua/Apt_t00ls环境&#xff1a;jdk1.8如果双…

【深度学习】PyTorch深度学习实践 - Lecture_11_Advanced_CNN

文章目录一、GoogLe Net1.1 网络结构1.2 Inception Model1.3 11 Convolution1.4 PyTorch-GPU 实现 GoogLe Net二、Residual Net2.1 梯度消失和梯度爆炸2.2 残差模块2.3 PyTorch-GPU 实现 Simple Residual Net2.3.1 整体结构2.3.2 残差块对象2.3.3 残差网络对象2.3.4 完整代码三…