当前位置: 首页 > news >正文

算法题目学习汇总

1、二叉树前中后序遍历:https://blog.csdn.net/cm15835106905/article/details/124699173
2、输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。

public class Solution {private TreeNode prev = null; // 用于记录链表的前一个节点private TreeNode head = null; // 头节点public TreeNode convertToDoublyLinkedList(TreeNode root) {if (root == null) {return null;}inOrderConvert(root);return head;}private void inOrderConvert(TreeNode node) {if (node == null) {return;}// 递归遍历左子树inOrderConvert(node.left);// 将当前节点链接到前一个节点if (prev == null) {// 当前节点是最左节点,赋值为头节点head = node;} else {// 将前一个节点的right指向当前节点prev.right = node;// 当前节点的left指向前一个节点node.left = prev;}// 更新前一个节点为当前节点prev = node;// 递归遍历右子树inOrderConvert(node.right);}public static void main(String[] args) {TreeNode root = new TreeNode(10);root.left = new TreeNode(6);root.right = new TreeNode(14);root.left.left = new TreeNode(4);root.left.right = new TreeNode(8);root.right.left = new TreeNode(12);root.right.right = new TreeNode(16);Solution solution = new Solution();TreeNode head = solution.convertToDoublyLinkedList(root);// 打印双向链表while (head != null) {System.out.print(head.val + " ");head = head.right;}}
}

解释:
变量定义:
prev 用于记录当前节点的前一个节点。
head 用于记录转换后的双向链表的头节点。
中序遍历: 使用递归的方式遍历二叉搜索树。对于每个节点:

递归遍历左子树。
处理当前节点,将 prev 节点的 right 指针指向当前节点,当前节点的 left 指针指向 prev 节点。
更新 prev 节点为当前节点。
递归遍历右子树。
输出双向链表:

转换完成后,我们可以遍历链表进行输出,验证结果是否正确。

3、二叉树深度在这里插入图片描述
在这里插入图片描述
4、

相关文章:

算法题目学习汇总

1、二叉树前中后序遍历:https://blog.csdn.net/cm15835106905/article/details/124699173 2、输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。 public class Solution {private Tr…...

DockerCompose中部署Jenkins(Docker Desktop在windows上数据卷映射)

场景 DockerJenkinsGiteeMaven项目配置jdk、maven、gitee等拉取代码并自动构建以及遇到的那些坑: DockerJenkinsGiteeMaven项目配置jdk、maven、gitee等拉取代码并自动构建以及遇到的那些坑_jenkins的安装以及集成jdkgitmaven 提示警告-CSDN博客 Windows10(家庭版…...

吊车报警的工作原理和使用场景_鼎跃安全

在现代建筑施工过程中,经常使用大型机械设备,如挖掘机、吊车、打桩机等,这些设备在施工过程中发挥着越来越重要的作用;同时,这些设备的作业频繁进行作业,对于接触到高压电线的风险也随之增加。大型机械设备…...

Spring5

文章目录 1. Spring 是什么?2. IoC3. Spring Demo4. IoC 创建对象的方式 / DI 方式注入的默认参数在哪里设定? 5. Spring 配置tx:annotation-driven 用于启用基于注解的事务管理 6. Bean的作用域7. 在Spring中有三种自动装配的方式1. 在xml中显式的配置2. 在java中…...

vue面试题二

一、请解释Vue中的双向数据绑定是什么? Vue中的双向数据绑定是一种机制,它使得数据的变化能够自动反映在用户界面上,同时用户界面中的输入也能够自动更新数据。这种机制实现了数据层(Model)和视图层(View&…...

软件设计师笔记-程序语言基础知识

编程语言之间的翻译形式 编程语言之间的翻译形式主要有三种:汇编、解释和编译。这三种方式在将源代码转换为机器可执行的代码时,有着各自的特点和流程。 汇编: 定义:汇编是低级语言(如汇编语言)到机器语言的一种翻译方式。汇编语言是为特定计算机或计算机系列设计的一种…...

在Windows上安装VMWare Pro 16.2(虚拟机)并从零安装CentOS 7.6镜像过程记录

本文详细记录了在Windows的VMWare Workstation Pro 16.2中安装CentOS 7.6 的过程,非常适合新手从零开始一步步安装。 文章目录 一、安装VMWare Workstation Pro 16.2并激活二、安装CentOS 7.62.1 下载CentOS7.6镜像文件2.2 创建新的虚拟机2.3 安装CentOS镜像一、安装VMWare Wo…...

NGINX之location和rewrite

一.NGINX常用的正则表达式 二.Location location作用:对访问的路径做访问控制或者代理转发 1.location 常用的匹配规则: 进行普通字符精确匹配,也就是完全匹配^~ / 表示普通字符匹配。使用前缀匹配。如果匹配成功,则不再匹配其它 …...

Python数据框的合并(一) -- merge函数

目录 1 merge 函数详解 1.1 左连接(Left Join): 1.2 右连接(Right Join): 1.3 全连接(Full Join 或 Outer Join): 2 代码示例 2.1 加载模块并创建示例数据框 2.2 左连接 2.3 右连接 2.4 全连接 1 m…...

【Qt秘籍】[010]-Qt常用控件

一、控件概述 在GUI(图形用户界面)开发领域,Qt无疑是众多开发者心中的首选框架之一。它不仅跨平台、功能强大,而且拥有丰富且灵活的控件库,使得开发者能够快速构建美观、高效的用户界面。对于初学者而言&#xff0…...

TypeScript基础教程学习

菜鸟教程 TypeScript基础类型 数字类型 number 双精度 64 位浮点值。它可以用来表示整数和分数。 let binaryLiteral: number 0b1010; // 二进制 let octalLiteral: number 0o744; // 八进制 let decLiteral: number 6; // 十进制 let hexLiteral: number 0xf00d…...

JavaSE面试

①.简述面向对象的三大特征 封装、继承、多态 1.封装: 概念: 是将类的某些信息隐藏在类的内部,不允许外部程序直接访问,而是通过该类提供的方法来实现对隐藏信息的操作和访问。 好处 : ①便于修改,增强了代…...

安全漏洞扫描工具

常用的安全漏洞扫描工具涵盖了网络扫描、Web应用扫描、系统漏洞检测等多个方面,以下是一些业界广泛认可和常用的工具: Nmap - 网络映射和安全审计工具,用于发现网络上的主机和服务,识别操作系统,枚举开放端口&#xff…...

前端开发部署:Visual Studio Code + vue

〇 说明 本教程全部采用默认安装路径,因为在进行自定义路径安装的时候,需要配置各种环境变量,在这个配置过程中,可能出现各种很混乱的问题。 一 安装Node.js 1 下载https://nodejs.org/en 2 按照默认NEXT执行 C:\Program Files…...

基于Sentry+OpenTelemetry实现微服务前后端全链路监控

文章目录 前⾔背景技术⽅案Sentry私有化部署部署环境准备 项目集成前端后端agent探针集成sentry sdk集成增强探针为⽇志注⼊TraceID异常处理SDK⾃定义开发sentry sdk⾃定义开发⾃定义SentryEvent注⼊otel追踪信息⾃定义全局异常上报issue事件新增动态过滤功能 Java Agent Exten…...

jquery.datetimepicker无法添加清除按钮的问题

项目场景: 自从决定用现有新技术实现CRM老项目起,就开始了我的折腾之路,最近一直在折腾前端页面,不像后端Java,写的有问题运行会报错,大多数报错一搜就能找到解决方案,前端这个倒好&#xff0c…...

Qt中解决编译中文乱码和编译失败的问题

解决方法 1.使用#pragma execution_character_set(“utf-8”) QT5中在cpp中使用#pragma execution_character_set(“utf-8”)解决中文乱码,不过这里要求该源代码必须保存成带Bom的utf-8格式,这也是有些在网上下载的代码,加上这句源代码后还…...

Android状态栏适配问题

Android状态栏适配是一个老生常谈的问题,那么我又拿出来讲了,因为这个东西确实太重要了,基本上每个项目都用得到。状态栏总共有几种形态。第一,让状态栏颜色跟应用主色调一致,布局内容不占有状态栏的位置。第二&#x…...

如何为色盲适配图形用户界面

首发日期 2024-05-25, 以下为原文内容: 答案很简单: 把彩色去掉, 测试. 色盲, 正式名称 色觉异常. 众所周知, 色盲分不清颜色. 如果用户界面设计的不合理, 比如不同项目只使用颜色区分, 而没有形状区分, 那么色盲使用起来就会非常难受, 甚至无法使用. 色盲中最严重的情况称为…...

【爬虫实战项目一】Python爬取豆瓣电影榜单数据

目录 一、环境准备 二、编写代码 2.1 分页分析 2.2 编码 一、环境准备 安装requests和lxml pip install requests pip install lxml 二、编写代码 2.1 分页分析 编写代码前我们先看看榜单的url 我们假如要爬取五页的数据,那么五个url分别是: htt…...

OpenCV图像处理:如何用Python实现自适应白平衡(附完整代码)

OpenCV图像处理实战:Python自适应白平衡算法深度解析 当你拍摄的照片总是偏蓝或偏黄时,可能不是相机出了问题,而是白平衡需要调整。作为计算机视觉开发者,掌握自适应白平衡算法能让你轻松解决这类色彩失真问题。本文将带你从原理到…...

RVC变声模型在IDEA开发环境中的调试技巧

RVC变声模型在IDE开发环境中的调试技巧 调试AI模型项目,尤其是像RVC(Retrieval-based Voice Conversion)这种涉及音频处理和深度学习的项目,常常让人头疼。你可能会遇到各种问题:代码在本地跑不通、张量形状对不上、模…...

【Multisim实战指南】工具栏全解析:从入门到高效设计

1. Multisim工具栏全景概览 刚接触Multisim时,面对密密麻麻的工具栏图标,很多新手都会感到无从下手。其实这些工具栏就像电工师傅的工具腰带,每个工具都有其专属用途。经过多年使用,我发现合理运用工具栏能提升至少50%的设计效率。…...

SUPER COLORIZER模型压缩技术:使用TensorRT加速推理并减少显存占用

SUPER COLORIZER模型压缩技术:使用TensorRT加速推理并减少显存占用 你是不是也遇到过这种情况?一个效果很棒的图像上色模型,比如SUPER COLORIZER,跑起来效果惊艳,但推理速度慢得像蜗牛,显存占用还高得吓人…...

别再手动P图了!用Python+OpenCV给图片批量加Logo水印,5分钟搞定

PythonOpenCV批量水印自动化:电商与自媒体工作流效率革命 每次处理上百张产品图时,最痛苦的不是修图调色,而是机械重复地拖动Logo到每个角落——这几乎是所有电商美工的日常噩梦。我曾用3小时完成200张新品上架图的品牌标识添加,直…...

告别HttpClient!用Hutool封装一个Spring Boot项目通用的HTTP工具类(含日志与JSON解析)

告别HttpClient!用Hutool打造Spring Boot项目的高效HTTP工具类 在Spring Boot后端开发中,HTTP请求是连接外部服务的常见需求。传统方式使用Apache HttpClient或RestTemplate往往伴随着冗长的配置和重复代码。Hutool作为Java工具库的瑞士军刀,…...

实战指南:使用Docker GPU部署CosyVoice 2的避坑与优化

最近在折腾语音合成项目,需要部署 CosyVoice 2 这个模型。直接本地部署吧,环境依赖太麻烦,换台机器又得重来一遍。用 Docker 倒是方便,但想用 GPU 加速,又踩了一堆坑。今天就把这次从踩坑到优化的完整过程记录下来&…...

手把手教你用Simulink和MATLAB搞定倒立摆:从物理建模到LQR控制器设计(附源码)

从零实现倒立摆控制:Simulink建模与LQR控制器实战指南 倒立摆系统作为控制理论中的"Hello World",完美诠释了如何用数学工具驯服物理世界的不稳定性。本文将带您完整走通从物理建模到控制器设计的全流程,不仅解释每一步的底层逻辑&…...

Friture音频可视化工具深度解析:从核心架构到实践配置

Friture音频可视化工具深度解析:从核心架构到实践配置 【免费下载链接】friture Real-time audio visualizations (spectrum, spectrogram, etc.) 项目地址: https://gitcode.com/gh_mirrors/fr/friture 核心组件解析 功能模块关联概览 Friture通过五大核心…...

单片机裸机编程的系统化工程实践

单片机裸机编程的系统化工程实践1. 裸机编程概念解析1.1 裸机编程的本质特征裸机编程(Bare-metal Programming)是指在无操作系统支持的硬件环境下直接编写控制程序的技术实践。在嵌入式系统领域特指基于单片机硬件平台的直接编程方法,其核心特征包括:直接…...