C++怎么实现二叉树的最小深度
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,今天小编给大家分享一下C++怎么实现二叉树的最小深度的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起
千家信息网最后更新 2025年12月02日C++怎么实现二叉树的最小深度
今天小编给大家分享一下C++怎么实现二叉树的最小深度的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
二叉树的最小深度
Example:
Given binary tree [3,9,20,null,null,15,7],
3
/
9 20
/
15 7
return its minimum depth = 2.
二叉树的经典问题之最小深度问题就是就最短路径的节点个数,还是用深度优先搜索 DFS 来完成,万能的递归啊。首先判空,若当前结点不存在,直接返回0。然后看若左子结点不存在,那么对右子结点调用递归函数,并加1返回。反之,若右子结点不存在,那么对左子结点调用递归函数,并加1返回。若左右子结点都存在,则分别对左右子结点调用递归函数,将二者中的较小值加1返回即可,参见代码如下:
解法一:
class Solution {public: int minDepth(TreeNode* root) { if (!root) return 0; if (!root->left) return 1 + minDepth(root->right); if (!root->right) return 1 + minDepth(root->left); return 1 + min(minDepth(root->left), minDepth(root->right)); }};我们也可以是迭代来做,层序遍历,记录遍历的层数,一旦遍历到第一个叶结点,就将当前层数返回,即为二叉树的最小深度,参见代码如下:
解法二:
class Solution {public: int minDepth(TreeNode* root) { if (!root) return 0; int res = 0; queue q{{root}}; while (!q.empty()) { ++res; for (int i = q.size(); i > 0; --i) { auto t = q.front(); q.pop(); if (!t->left && !t->right) return res; if (t->left) q.push(t->left); if (t->right) q.push(t->right); } } return -1; }}; 以上就是"C++怎么实现二叉树的最小深度"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。
结点
深度
最小
知识
篇文章
递归
函数
C++
代码
内容
就是
解法
问题
不同
很大
个数
大部分
更多
知识点
经典
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
浙江加工刀片服务器设计
伊春商城分销软件开发多少钱
美国存储型服务器
锡山区多功能软件开发注意事项
南阳网络技术销售价格
数据库教程.pdf
网络安全进校园新闻稿文案
容易上手的软件开发技术
公安网络安全学习体会
凯乐科技工业互联网5g
未能找到使用主机号的服务器
服务器arp防火墙
宝中国网络技术有限公司
长春专业的网络安全机构十大品牌
用友软件开发工具
江阴三喜网络技术有限公司
赛康服务器
四川党员量化积分管理软件开发
揭阳市委网络安全紧缺人才
计算机网络技术网课公众号
无线网络技术期末论文
保障网络安全工作落实自查
昆山电子网络技术怎么样
服务器咋造
进销存软件数据库还原
软件开发不正当竞争案例
杭州银闪网络技术
服务器风扇启动慢
中学生的网络安全应注意什么
互联网科技的好处