C++怎么实现二叉树的最小深度
发表于:2025-02-04 作者:千家信息网编辑
千家信息网最后更新 2025年02月04日,今天小编给大家分享一下C++怎么实现二叉树的最小深度的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起
千家信息网最后更新 2025年02月04日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; queueq{{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安全错误
数据库的锁怎样保障安全
预防网络安全意识
四川航空笔软件开发面试
网络安全恶意网络连接请求
服务器开机滴滴报警
毕业设计数据库展示
数据库营销的企业案例
南昌软件开发公司
服务器安全狗误拦截
复兴号网络安全车顶
工行软件开发工作内容
两个数据库的表关联查询
附加数据库错误602
亨达海天网络技术有限公司
2021中国互联网大会数据库
国产化 服务器
软件开发的员工薪酬
我的世界服务器樱花穿透
数据库怎么生成exe
互联网信息网络安全基础
网络安全项目驻场
云音响的服务器为什么会断开
机器人集成服务器有哪些
密云区专业性网络技术服务优点
广州御图网络技术有限公司
服务器共享session
达梦数据库字段名限制
网络安全洞见
可以打空岛战争的服务器
网络安全管理机构配备专门人员
矿机服务器换了是不是算力高很多