树、二叉树、图

news2025/4/16 7:05:27

在这里插入图片描述
在这里插入图片描述

struct TreeNode {
  int val;
  TreeNode* left;
  TreeNode* right;
  TreeNode(int x): val(x), left(nullptr), right(nullptr) {} 
}

二叉树的遍历

在这里插入图片描述

  • 前序 Pre-Order:根 - 左子树 - 右子树:A BDHIEJCFG
  • 中序 In-Order:左子树 - 根 - 右子树:HDIBJE A FCG
  • 后序 Post-Order:左子树 - 右子树 - 根:HIDJEBFGC A
  • 层次序:A BCDEFG HIJ

在这里插入图片描述

  • 树的前序遍历又称树的深度优先遍历
  • 树的层序遍历又称树的广度优先遍历

LeetCode 练习题

  • 226. 翻转二叉树
  • 98. 验证二叉搜索树
  • 104. 二叉树的最大深度
  • 111. 二叉树的最小深度
  • 94. 二叉树的中序遍历
  • 144. 二叉树的前序遍历
  • 145. 二叉树的后序遍历
  • 102. 二叉树的层序遍历
  • 589. N 叉树的前序遍历
  • 590. N 叉树的后序遍历
  • 429. N 叉树的层序遍历
  • 559. N 叉树的最大深度
  • 297. 二叉树的序列化与反序列化
  • 543. 二叉树的直径
  • 236. 二叉树的最近公共祖先

基环树

  • 向一棵树添加一条边,就形成了一个环
  • 此时整个结构被称为基环树(pseudotree / unicycli graph)
    在这里插入图片描述

  • 链表是特殊化的树
  • 树是特殊化的图
    • N 个点 N - 1 条边的连通无向图 - 树
    • N 个点 N 条边的连通无向图 - 基环树

在这里插入图片描述


图的存储

  • 定义
    • 邻接矩阵 O ( n 2 ) O(n^2) O(n2)int graph[MAX_N][MAX_N];
    • 出边数组 O ( n + m ) O(n + m) O(n+m)vector<int> graph[MAX_N]; vector<vector<int>> graph;
    • 邻接表 O ( n + m ) O(n + m) O(n+m)struct Node { int to; Node* next; }; Node* head[MAX_N];
  • 新增边 ( x , y ) (x, y) (x,y)
    • 邻接矩阵:graph[x][y] = 1;
    • 出边数组:graph[x].push_back(y);
    • 邻接表:Node * node = new Node(); node->to = y; node->next = head[x]; head[x] = node;
      在这里插入图片描述
      在这里插入图片描述

图的遍历

  • 深度优先遍历

    • 划分连通块
      在这里插入图片描述
  • 广度优先遍历

    • 拓扑排序
      在这里插入图片描述

LeetCode 练习题

  • 684. 冗余连接
  • 207. 课程表
  • 210. 课程表 II

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

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

相关文章

Docker进阶篇-DockerFile

一、简介 Dockerfile是用来构建Docker镜像的文本文件&#xff0c;是由一条条构建镜像所需的指令和参数构成的脚 本。 构建步骤&#xff1a; 1、编写Dockerfile文件 2、docker build命令构建镜像 3、docker run依镜像运行容器实例 二、Docker构建过程解析 1、Dockerfile…

[Vue3] useRoute、useRouter

useRoute 返回当前路由地址。相当于在模板中使用 $route。必须在 setup() 中调用。用于在组件中获取当前路由的信息&#xff0c;返回一个包含路由信息的对象。这个函数适用于那些不需要监听路由变化的场景&#xff0c;只是获取当前路由信息的静态数据。 useRouter 返回 route…

高精度GNSS接收机尾矿库监测应用

高精度GNSS接收机在尾矿库监测中广泛应用&#xff0c;它能够提供位移精确测量&#xff0c;以及全面而详细多维度的数据监测。通过与其他监测设备的联动&#xff0c;可以实现了对尾矿库坝体位移、变形、坝体浸润线、库内水位、库区降雨量、安全视频的全面自动化监测及预警&#…

Django模型(九)

一、使用SQL语句 1.1、通过模型使用SQL 通过raw函数执行原始SQL语句进行查询,主键字段必须包含在查询的字段中,不然会引发错误 : # 定义个 Cook 模型 class Cook(models.Model):"""厨师"""name = models.CharField(max_length=32,verbose_n…

Mac如何设置一位数密码?

一、问题 Mac如何设置一位数密码&#xff1f; 二、解答 1、打开终端 2、清除全局账户策略 sudo pwpolicy -clearaccountpolicies 输入开机密码&#xff0c;这里是看不见的&#xff0c;输入完回车即可 3、重新设置密码 &#xff08;1&#xff09;打开设置-->用户和群组…

html,css,js速成

准备&#xff1a;vscode配好c&#xff0c;python&#xff0c;vue环境。 1. html hypertext markup language(超文本标记语言) 1. 基础语法 一个html元素由开始标签&#xff0c;填充文本&#xff0c;结束标签构成。 常见标签说明<b></b>粗体<i></i>…

浅谈安科瑞为数据中心领域提供能效管理解决方案

一、前言 推进工业能效提升&#xff0c;是产业提质升级、实现高质量发展的内在要求&#xff0c;是降低工业领域碳排放、实现碳达峰碳中和目标的重要途径&#xff0c;是培育形成绿色低碳发展新动能、促使工业经济增长的合理举措。为深入贯彻落实党国、国务院重大决策部署&#…

开阳630hv100的代码编译以及软件制作步骤

打开项目功能步骤&#xff1a; 编译awtk功能&#xff1a; 选中awtk工程&#xff0c;先编译一次awtk sdk&#xff08;如下图的3和4步骤&#xff09;&#xff1b; 编译项目代码&#xff08;如下图步骤5和6&#xff09;&#xff1b; 编译完成后&#xff0c;软件路径&#xff1a;…

Hugging Face: 拥开源模型社区

Hugging face是一个开源的模型社区&#xff0c;里边包含各种各样的模型。Hugging face在github上开源了一个Transformers库&#xff0c;这个库非常的好用&#xff0c;我们可以用这个库做模型的推理、微调。推荐这个库的另一个原因是简单好用&#xff0c;我们看一下huggingface的…

使用Postman做API自动化测试

Postman最基本的功能用来重放请求&#xff0c;并且配合良好的response格式化工具。 高级点的用法可以使用Postman生成各个语言的脚本&#xff0c;还可以抓包&#xff0c;认证&#xff0c;传输文件。 仅仅做到这些还不能够满足一个系统的开发&#xff0c;或者说过于琐碎&#…

空间算法:四叉树

更多精彩内容尽在数字孪生平台。 简要 我们首先想象一个场景&#xff0c;根据用户位置找出给定半径内有哪些咖啡店。最直接的做法是检查数据集中所有咖啡店的纬度/经度位置是否落在给定半径内。虽然我们可以轻松地做到这一点&#xff0c;但在 n 个位置的数组中&#xff0c;我们…

C语言第十五弹---操作符(上)

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】 操作符 1、操作符的分类 2、二进制和进制转换 2.1、2进制转10进制 2.1.1、10进制转2进制数字 2.2、2进制转8进制和16进制 2.2.2、2进制转16进制 3. 原码、反…

王道_数据结构 1.2_2_算法的时间复杂度

1.2_2_算法的时间复杂度 一、为什么要事先预估算法时间开销二、时间复杂度的计算与技巧1、化简“算法时间开销”的计算方式的依据2、常用技巧&#xff08;1&#xff09;加法、乘法规则&#xff08;2&#xff09;时间复杂度的数量级阶数排行 3、计算时间复杂度的结论与步骤&…

#{}和${}的区别

#{}和${}的区别 .本质区别:使用注意事项防止SQL注入排序like查询 . 在使用mybatis操作数据库的时候,我们在编写sql语言的时候,会遇到一个问题,就是在传参的时候,有两个符号#,$.这两个符号有什么异同呢,接下来,我就会带着大家对这个问题进行简单的探讨 本质区别: #执行的是预编…

猫什么时候发腮?性价比高的发腮主食冻干推荐

猫什么时候发腮&#xff1f;发腮是猫咪成长过程中一个重要的体征&#xff0c;也是猫父母们非常关心的问题。想要让猫咪拥有可爱的肉嘟嘟脸型&#xff0c;主人需要在适龄的年龄段加强营养补给&#xff0c;不要错失最佳发腮期。猫什么时候发腮呢&#xff1f;应该怎样喂养才能让猫…

DevOps落地笔记-03|用户故事:对用户需求达成共识的关键

上一讲主要跟你介绍了如何使用影响地图这个工具来进行产品定义、里程碑规划和用户需求分析。影响地图让我们始终以达到目标为核心&#xff0c;并让功能和需求不偏离该目标&#xff0c;从而让交付更有重点。可视化、结构化的思维导图为技术和业务人员创建了共享的整体视图&#…

【安装指南】nodejs下载、安装与配置详细教程

目录 &#x1f33c;一、概述 &#x1f340;二、下载node.js &#x1f337;三、安装node.js &#x1f341;四、配置node.js &#x1f33c;一、概述 Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时&#xff0c;用于构建可扩展的网络应用程序。Node.js 使用事件驱动、…

中移(苏州)软件技术有限公司面试问题与解答(6)—— Linux内存管理之内存规整

接前一篇文章&#xff1a;中移&#xff08;苏州&#xff09;软件技术有限公司面试问题与解答&#xff08;0&#xff09;—— 面试感悟与问题记录 本文内容参考&#xff1a; linux内存管理笔记(四十二&#xff09;----内存规整 特此致谢&#xff01; 本文对于中移&#xff08;…

安卓视图基础

目录 设置视图的宽高 设置视图的间隔 设置视图的对齐方式 设置视图的宽高 设置视图的间隔 设置视图的对齐方式 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"a…

【日常问题】Failed to enable unit: Unit file docker.service does not exist.

Failed to enable unit: Unit file docker.service does not exist. 1. 问题原因 笔者问题的产生是因为在ubuntu20.04下采用snapd安装的docker&#xff0c;因此 systemctl restart docker.servicesystemd并不能找到守护进程docker.service 同时使用docker命令时还会产生若干…