数据结构 -- 二叉树

news/2024/5/3 3:02:58

简介 :  

二叉树有左右两个子节点 ;

我们可以用一个包含左孩子和右孩子的结构体数组来存储二叉树 : 

const int N = 1e6 + 10 ;// 存储 : 
struct Node{int l , r ;
}a[N];

读入 : 
 

    for(int i=1;i<=n;i++) cin >> a[i].l >> a[i].r ;

用链表实现参考 : 

二叉树基础知识总结-CSDN博客

例题 : 

1 . 二叉树深度

【深基16.例3】二叉树深度 - 洛谷

可以先遍历左子树,然后遍历右子树 , 如果存在,则高度加一;

对于判断叶子节点 : 只需要判断是否值为0即可 ;

#include<bits/stdc++.h>
using namespace std;const int N = 1e6 + 10 ;// 存储 : 
struct Node{int l , r ;
}a[N]; int n , ans ;void dfs(int i , int d){if(i==0) return ; // 叶子结点 // 处理结点ans = max(ans , d) ; dfs(a[i].l , d + 1) ; // 左子树 dfs(a[i].r , d + 1) ; // 右子树 
}int main(){int n ; cin >> n ;// 读入 for(int i=1;i<=n;i++) cin >> a[i].l >> a[i].r ;dfs(1,1) ; // 从根节点出发 , 初始深度为1cout << ans << endl ; 
}

2 . P4715 淘汰赛

【深基16.例1】淘汰赛 - 洛谷

虽然实现上和二叉树没有什么关系(用队列实现)

#include<bits/stdc++.h>
using namespace std ;
typedef pair<int,int> PII ;
int main(){queue<PII> q ;int n ; cin >> n ;n = 1<<n ;for(int i=1;i<=n;i++) {int x ; cin >> x  ;q.push({x,i}) ;} while(q.size() > 2){auto x = q.front() ; q.pop() ;auto y = q.front() ; q.pop() ;if(x.first > y.first){q.push(x) ;} else{q.push(y) ;}} auto x = q.front() ; q.pop() ;auto y = q.front() ; q.pop() ;if(x.first > y.first){cout << y.second << endl ;}else {cout << x.second << endl ; }
}


http://www.mrgr.cn/p/08635707

相关文章

Java 的注释

文章目录 java 的注释共有三种形式单行注释多行注释文档注释文档注释的文档需要命令进行生成GBK 不可映射问题 与大多数的编程语言一样&#xff0c;Java 中的注释也不会出现在可执行程序中。 因此我们可以在源程序中根据需要添加任意多的注释&#xff0c;而不必担心可执行代码受…

jenkins从节点配置说明

目的 打包构建时使用从节点&#xff0c;从节点所在服务器配置4C8G5000G&#xff08;服务器2&#xff09; 前提 首先在服务器1上部署jenkins服务&#xff0c;即主节点&#xff0c;默认节点名称为master 步骤 1&#xff09;登录进入jenkins平台&#xff0c;在系统设置中&…

一个静态页面接入科大讯飞3.5AI

静态文件html<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible&q…

\x 开头编码的数据解码成中文

在宾馆让单片机连wifi,可惜不能显示汉字,显示都是utf-8码:可以用python解读这些 \x开头的字符串,比如第一个 \xe4\xb8\x89\xe4\xb8\x91\xe5\xae\xbe\xe9\xa6\x864 可以在python 输入以下命令: 先把错误的方式展示给你: # 错误的使用方式 s = "你好世界" decode…

Linux读写文件

前言 学习了文件系统&#xff0c;就能理解为什么说Linux下一切皆文件。 语言层面的操作 在c语言的学习中我们可以使用fopen()函数对文件进行操作。 int main() {//FILE * fp fopen("./log.txt", "w");//FILE * fp fopen("./log.txt", "…

OpenStack 入门体验

目录 一、云计算概述 1.1、什么是云计算 1.2、云计算的服务模型 1&#xff09;IaaS 2&#xff09;PaaS 3&#xff09;SaaS 1.3、OpenStack 概述 1&#xff09;OpenStack 起源 2&#xff09;什么是 OpenStack 3&#xff09;OpenStack 优势 二、OpenStack 一…

品牌百度百科词条创建多少钱?

百度百科作为国内最具权威和影响力的知识型平台&#xff0c;吸引了无数品牌和企业争相入驻。一个品牌的百度百科词条&#xff0c;不仅是对品牌形象的一种提升&#xff0c;更是增加品牌曝光度、提高品牌知名度的重要途径。品牌百度百科词条创建多少钱&#xff0c;这成为了许多企…

Ubuntu 22.04中使用微信

刚开始装了一个优麒麟原装的微信,真的好难用,就只能发送接受个文字消息,所以还是推荐安装wine版本的,链接如下:https://www.ubuntukylin.com/applications/119-cn.html 还是推荐离线安装,在线安装wine环境时容易出问题,根据它的教程安装即可~ 1、Wine环境安装: 下载链…

解析SAP系统在企业成本管理中的关键作用与优势

成本管理对于企业的可持续发展至关重要,而SAP系统作为领先的企业资源规划软件,在企业成本管理中发挥着重要作用。本文将分析SAP系统在企业成本管理中的重要性,探讨SAP系统如何帮助企业降低成本、提高效率,以及实现可持续发展的过程。第一部分:SAP系统的全面性 SAP系统是企…

python 正则表达式匹配

re模块: 案例: python的贪婪和非贪婪 r的作用:

python 修改jenkins的配置文件

python有jenkins获取配置文件的api,也有修改配置文件的api, 下面介绍下 如果修改jenkins job的配置文件内容:import re import time import jenkinsjenkins_url="http://xxx.com/jenkins" username="zhangsan" token="1.......de"jenkins = je…

基于SkyEye运行Qt:著名应用程序开发框架

Qt是一个著名的跨平台的C++图形用户界面应用程序开发框架,目前包括Qt Creator、Qt Designer等等快速开发工具,还支持2D/3D图形渲染、OpenGL,允许真正的组件编程,是与GTK、MFC、OWL、ATL一样的图形界面库。使用Qt开发的软件可以做到一次开发、任意部署,相同的代码可以在任意…

Apple App Store API 快速获取app综合评分,最新评论

iDataRiver平台 https://idatariver.com 提供开箱即用的app store采集api,可快速获取app的公开信息,包括app综合评分,用户评论,版本记录,以及搜索app等,能快速获取市场的反馈从而提升运营效率。iDataRiver平台 https://www.idatariver.com/zh-cn/ 提供开箱即用的苹果应用…

6、JVM-JVM调优工具与实战

前置启动程序 事先启动一个web应用程序&#xff0c;用jps查看其进程id&#xff0c;接着用各种jdk自带命令优化应用 Jmap 此命令可以用来查看内存信息&#xff0c;实例个数以及占用内存大小 jmap -histo 14660 #查看历史生成的实例 jmap -histo:live 14660 #查看当前存活的实…

Stable Diffusion 3 API 发布!超越Midjourney v6和DALL-E 3

Stable Diffusion 3 于 2 月首次宣布作为预览版发布。而今天&#xff0c;StabilityAI 正式推出了 Stable Diffusion 3 和 Stable Diffusion 3 Turbo API 的API接口服务。 Stability AI 称仍在持续改进该模型&#xff0c;并没有说明发布日期。模型还没发布&#xff0c;但API先来…

说说你对图的理解?相关操作有哪些?

一、是什么 在计算机科学中,图是一种抽象的数据类型,在图中的数据元素通常称为结点,V是所有顶点的集合,E是所有边的集合 如果两个顶点v,w,只能由v向w,而不能由w向v,那么我们就把这种情况叫做一个从 v 到 w 的有向边。v也被称做初始点,w也被称为终点。这种图就被称做有向…

【机器学习】第二节-如何选择和评估模型

目录一、经验误差与过拟合错误率精度误差训练误差/经验误差度量指标泛化误差欠拟合过拟合二、评估方法专家样本1.留出法(1)单次留出法(2)多次留出法2.交叉验证(1)k折交叉验证(2)留一法(3)P次k折交叉验证3.自助法三、性能度量四、偏差与方差 一、经验误差与过拟合 错误率 分类错…

找win的局域网ip方式

执行命令ipconfig,结果如下这样跟你同一网络的小伙伴就能找到你啦

linux input system 分析笔记

1 struct input_dev 和 struct input_handler 1.1 简介 struct input_dev表示一个设备驱动层的输入设备。 struct input_handler是处理struct input_dev上报的事件的事件处理器。 1.2 全局变量input_dev_list&#xff0c;input_handler_list 输入设备链表&#xff1a;input…