《数据结构风云》递归算法:二叉树遍历的精髓实现

《数据结构风云》递归算法:二叉树遍历的精髓实现


在这里插入图片描述

🔥@晨非辰Tong: 个人主页
👀专栏:《C语言》《数据结构与算法入门指南》
💪学习阶段:C语言、数据结构与算法初学者
⏳“人理解迭代,神理解递归。”


文章目录


引言

代码修行路上,你是否曾为盘根错节的二叉树所困?今日,我便传你一门无上法门——递归分神之术。
此法看似玄奥,实则暗合天道。面对复杂树结构,只需一剑化三清:本尊镇守当前,分神各巡左右。如此层层分化,直至洞悉所有脉络。
修得此术,任他树中有树、套中有套,你自能一眼洞穿虚实。三式法诀,助你练就火眼金睛,识破万千子树真伪。

》–获取源码–点我《


一、单值二叉树

965. 单值二叉树

1.目标特征描述:什么单值二叉树

在这里插入图片描述

2.目标实现示例:

在这里插入图片描述

3.算法思路:

先对简单二叉树进行算法推理,再推广到整体。

在这里插入图片描述
递归规则:先递进再返回。
递进:首先从根节点root开始,左子树如果存在先对左子树匹配判断:若二者数值不相等,就返回false,反之继续对右子树进行判断:二者数值不相等,返回false。当然,根节点为空返回true。推广到整体,就遍历左右子树判断。
返回:整个二叉树已经递进判断完毕,要对函数从最后开始返回:看图示,第2节点的左右子节点(&&的和关系)为空,那么都返回true,代表这个子树是单值的。右子树第3节点也是单值的。那么根节点的两个子树就都返回true&&的和关系),代表整体是单值二叉树。

3.1 具体代码实现

/** * Definition for a binary tree node. * struct TreeNode { * int val; * struct TreeNode *left; * struct TreeNode *right; * }; */ bool isUnivalTree(structTreeNode* root){//首先判断树是否为空if(root ==NULL){return true;}//存在左子树再匹配if(root->left && root->val != root->left->val){return false;}if(root->right && root->val != root->right->val){return false;}returnisUnivalTree(root->left)&&isUnivalTree(root->right);}
  • 时间复杂度: O(N);
  • 空间复杂度: O(N);
在这里插入图片描述

二、相同的树

100. 相同的树

1.目标特征描述:什么是相同的树

在这里插入图片描述

2.目标实现示例

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

3.算法思路

在这里插入图片描述
情况分类两根节点情况结果
1两个根节点都为空是相同的树
2一个根节点为空,另一个不为空不是相同的树
3两个根节点都不为空比较节点数值进一步判断
--根据函数递归规则:
递进:从两个树根节点进行对比,第1种情况两个根节点都为空(代表没有子节点)就返回true;第2种情况一个根节点为空,另一个根节点不为空,两个树的结构不同,就返回false;第3种情况两个根节点都不为空,那么就要判断两个节点的数值,不相等就返回false。最后开始调用函数对比二者的左右子树。
返回:从函数的最后开始返回。看图示,从二者的第2个节点的左右子树开始对比,左右节点都为空返回true&&的和关系),代表两个二叉树的第2节点为根节点子树为相同的树。同理,二者的以第3个节点为根节点的子树也是相同的树。以此类推,根节点的左右子树都是相同的树(&&的关系),代表两个二叉树为相同的二叉树。

3.1 具体代码实现

/** * Definition for a binary tree node. * struct TreeNode { * int val; * struct TreeNode *left; * struct TreeNode *right; * }; */ bool isSameTree(structTreeNode* p,structTreeNode* q){//两个根节点都为空-->结构相同if(p ==NULL&& q ==NULL){return true;}//只有一个根节点为空-->结构不同if(p ==NULL|| q ==NULL){return false;}//两个根节点都不为空,但值不相等if(p->val != q->val){return false;}//否则继续遍历判断子树returnisSameTree(p->left, q->left)&&isSameTree(p->right, q->right);}
在这里插入图片描述

三、另一棵树的子树

572. 另一棵树的子树

1.目标特征描述

在这里插入图片描述

2.目标实现示例

在这里插入图片描述

3.算法思路

基本算法:首先,如果根节点为空,就不需要与目标树再进行对比。不为空,就利用前面实现的判断是否是相同的树接口进行判断。不匹配,就调用函数遍历子树(注意:当左子树匹配成功,就不需要再对右子树进行判断 )。

3.1 具体代码实现

/** * Definition for a binary tree node. * struct TreeNode { * int val; * struct TreeNode *left; * struct TreeNode *right; * }; */typedefstructTreeNode TreeNode; bool isSametree(TreeNode* p, TreeNode* q){//第1种情况,两个书都为空if(p ==NULL&& q ==NULL){return true;}//第2种情况,其中1个根节点为空if(p ==NULL|| q ==NULL){return false;}//第3种情况,2个根节点存在,但是数值不相同if(p->val != q->val){return false;}//数值相同,向下进行调用函数判断子树returnisSametree(p->left, q->left)&&isSametree(p->right, q->right);} bool isSubtree(structTreeNode* root,structTreeNode* subRoot){if(root ==NULL){return false;}//调用判断最开始时根节点是否匹配if(isSametree(root, subRoot)){return true;}//根节点不匹配,向下递归调用returnisSubtree(root->left, subRoot)||isSubtree(root->right,subRoot);}
在这里插入图片描述

四、对称二叉树

101. 对称二叉树

1.目标特征描述

在这里插入图片描述

2.目标实现示例

3.算法思路

首先根节点为空,代表树为空,一定是对称的。不为空,将根节点的左右子树判断结构是否对称——>改变一下前面实现相同的树的接口:return isSametree(p->left, q->right) && isSametree(p->right, q->left);,因为让左右对应进行对比。
如果函数判断后,返回的false,那么就直接返回false

3.1 具体代码实现

/** * Definition for a binary tree node. * struct TreeNode { * int val; * struct TreeNode *left; * struct TreeNode *right; * }; */typedefstructTreeNode TreeNode; bool isSametree(TreeNode* p, TreeNode*q){//根节点都为空if(p ==NULL&& q ==NULL){return true;}//一个根节点为空if(p ==NULL|| q ==NULL){return false;}//不为空,但是数值不同if(p->val != q->val){return false;}//以上均不满足,代表这两个节点相同,遍历子树继续判断returnisSametree(p->left, q->right)&&isSametree(p->right, q->left);} bool isSymmetric(structTreeNode* root){//树为空if(root ==NULL){return true;}//树不为空,将左右子树进行对比,看结构是否对称if(isSametree(root->left, root->right)){return true;}return false;}

总结

道阻且长,行则将至
四大递归心法已传授完毕,但这只是算法修真的起点。递归分神的精髓,将在后续的图论、动态规划等秘境中继续发挥威力。
保持这份求道之心,我们下期「回溯秘境」再会!
愿每一位码农修行者,都能在算法之道上突破自我。

Read more

Android WebRTC 播放流实战:从协议解析到性能优化

快速体验 在开始今天关于 Android WebRTC 播放流实战:从协议解析到性能优化 的探讨之前,我想先分享一个最近让我觉得很有意思的全栈技术挑战。 我们常说 AI 是未来,但作为开发者,如何将大模型(LLM)真正落地为一个低延迟、可交互的实时系统,而不仅仅是调个 API? 这里有一个非常硬核的动手实验:基于火山引擎豆包大模型,从零搭建一个实时语音通话应用。它不是简单的问答,而是需要你亲手打通 ASR(语音识别)→ LLM(大脑思考)→ TTS(语音合成)的完整 WebSocket 链路。对于想要掌握 AI 原生应用架构的同学来说,这是个绝佳的练手项目。 从0到1构建生产级别应用,脱离Demo,点击打开 从0打造个人豆包实时通话AI动手实验 Android WebRTC 播放流实战:从协议解析到性能优化 在移动直播、在线教育、视频会议等场景中,WebRTC技术凭借其低延迟、点对点通信的特性成为首选方案。但在Android平台上实现稳定流畅的播放流,

By Ne0inhk

Qwen3-VL-WEBUI部署避坑:常见启动失败原因及解决方案

Qwen3-VL-WEBUI部署避坑:常见启动失败原因及解决方案 1. 背景与场景介绍 1.1 Qwen3-VL-WEBUI 是什么? Qwen3-VL-WEBUI 是基于阿里云开源的 Qwen3-VL-4B-Instruct 模型构建的一站式可视化推理界面,专为多模态任务设计。它允许用户通过图形化操作完成图像理解、视频分析、GUI代理控制、OCR识别、代码生成等复杂任务,极大降低了大模型在视觉语言场景下的使用门槛。 该WEBUI通常以内置镜像形式提供,支持一键部署于本地或云端GPU服务器(如NVIDIA RTX 4090D),适用于开发者、研究人员和企业级应用团队快速验证多模态能力。 1.2 部署痛点为何频发? 尽管官方提供了“一键部署+自动启动”的理想流程(如“部署镜像 → 等待启动 → 点击访问”),但在实际落地过程中,大量用户反馈出现服务无法启动、端口绑定失败、依赖缺失、显存溢出等问题。这些问题往往源于环境配置不当、资源不足或镜像版本缺陷。 本文将系统梳理 Qwen3-VL-WEBUI 常见启动失败场景,结合真实工程经验,提供可落地的排查路径与解决方案,帮助你绕

By Ne0inhk

2026年多模态AI落地趋势:Qwen3-VL-WEBUI+弹性GPU部署详解

2026年多模态AI落地趋势:Qwen3-VL-WEBUI+弹性GPU部署详解 1. 引言:多模态AI进入规模化落地关键期 随着大模型技术从纯文本向视觉-语言一体化演进,2026年将成为多模态AI真正“走出实验室、走进产线”的关键一年。在这一进程中,阿里云推出的 Qwen3-VL 系列模型凭借其强大的视觉理解与生成能力,正成为工业界和开发者社区关注的焦点。 而为了让这一先进模型更易用、更贴近实际场景,社区迅速孵化出 Qwen3-VL-WEBUI —— 一个集成了模型推理、交互式界面与轻量化部署能力的开源项目。结合弹性GPU资源调度机制,开发者可实现“一键部署 + 按需扩容”的高效落地模式。 本文将深入解析: - Qwen3-VL-WEBUI 的核心架构与功能亮点 - 阿里开源版本的技术特性(内置 Qwen3-VL-4B-Instruct) - 如何通过弹性GPU实现低成本、高可用的生产级部署 - 实际应用场景中的性能表现与优化建议 帮助你在新一轮多模态浪潮中抢占先机。 2. Qwen3-VL-WEBUI 核心能力深度解析 2.1 什么是 Qwen3-VL-WEBUI?

By Ne0inhk
[开源推荐] 基于 Vue 3 + Hiprint 的 Web 打印设计器 vg-print:拖拽设计、静默打印一站式方案

[开源推荐] 基于 Vue 3 + Hiprint 的 Web 打印设计器 vg-print:拖拽设计、静默打印一站式方案

在 Web 开发中, 打印功能 一直是一个让人头疼的痛点。传统的 CSS 打印难以精确控制分页、页眉页脚和复杂布局,而市面上的打印插件要么收费昂贵,要么集成复杂。 最近在项目中基于著名的 hiprint 库,封装了一套 开箱即用 的 Vue 3 打印设计组件库 —— vg-print 。它不仅支持可视化拖拽设计模板,还集成了预览、PDF/图片导出,甚至支持配合客户端实现 静默打印 。今天就把这个开源项目分享给大家,希望能帮到有类似需求的开发者。 为什么选择 vg-print? vg-print 是一个基于 Vue 3 生态的打印解决方案。它不仅仅是对 hiprint 的简单封装,更提供了一个完整的 FullDesigner 设计器组件。 核心痛点解决: * 可视化设计 :不再手写复杂的打印样式,直接拖拽生成模板。 * 开箱即用 :引入组件即可使用,无需繁琐的初始化配置。 * 功能全面

By Ne0inhk