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

门户网站建设困难网站建设企业模板丫

门户网站建设困难,网站建设企业模板丫,网站备案全国合作拍照点 腾讯云,网站开发如何使用API文章目录 题目递归代码深度优先搜索(DFS)代码深度优先搜索原理图及解释广度优先搜索(BFS)代码广度优先搜索原理图及解释结束 题目 二叉树:二叉树的最大深度 给定一个二叉树 root ,返回其最大深度。 二叉树…

文章目录

    • 题目
    • 递归代码
    • 深度优先搜索(DFS)代码
    • 深度优先搜索原理图及解释
    • 广度优先搜索(BFS)代码
    • 广度优先搜索原理图及解释
    • 结束

题目

二叉树:二叉树的最大深度
给定一个二叉树 root ,返回其最大深度。

二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。

示例 1:
在这里插入图片描述

输入:root = [3,9,20,null,null,15,7]
输出:3
示例 2:

输入:root = [1,null,2]
输出:2

提示:

树中节点的数量在 [0, 104] 区间内。
-100 <= Node.val <= 100

递归代码

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:int maxDepth(TreeNode* root) {if(!root){return 0;}return max(maxDepth(root->left),maxDepth(root->right))+1;}
};

深度优先搜索(DFS)代码

超出内存限制


/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:int maxDepth(TreeNode* root) {if(!root){return 0;}int depth=0;stack<pair<TreeNode*,int>> s;s.push({root,1});while(!s.empty()){auto temp=s.top();s.pop();depth=max(depth,temp.second);if(temp.first->right){s.push({temp.first,temp.second+1});}if(temp.first->left){s.push({temp.first,temp.second+1});}}return depth;}
};

深度优先搜索原理图及解释

在这里插入图片描述
需要用到栈
①首先将结点3压栈,深度为1,与初始化的深度大小比较,然后3出栈。
②遍历结点3的右子树20入栈深度为2,左子树9入栈深度为2,栈顶元素9出栈,比较深度,找9的左右子树为空。
③栈顶元素20出栈,比较深度大小,遍历左右子树,7入栈深度为3,15入栈深度为3。
④栈顶元素15出栈,比较深度大小,遍历左右子树为空。
⑤栈顶元素7出栈,比较深度大小,最大深度为3,遍历左右子树为空。
⑥栈为空,循环结束,返回最大深度。

广度优先搜索(BFS)代码

内存超出限制

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:int maxDepth(TreeNode* root) {if(!root){return 0;}queue<pair<TreeNode*,int>> q;int depth=0;q.push({root,1});while(!q.empty()){auto temp=q.front();q.pop();depth=max(depth,temp.second);if(temp.first->left){q.push({temp.first,temp.second+1});}if(temp.first->right){q.push({temp.first,temp.second+1});}}return depth;}
};

广度优先搜索原理图及解释

需要用到队列
在这里插入图片描述
初始化深度为0
①首先3入队,深度为1,保存好结点3,结点3出队,比较深度大小,将3的左右子树9、20入队,深度为2
②9出队,比较深度大小,左右子树为空。
③20出队,比较深度大小,左右子树入队15、7深度为3。
④15出队,比较深度大小,左右子树为空。
⑤7出队,比较深度大小,左右子树为空,最大深度为3。
⑥整个队列为空循环结束,返回最大深度。

结束

在这里插入图片描述

原理图借鉴哔站华南溜达虎,如有侵权联系删除。

http://www.dtcms.com/wzjs/807761.html

相关文章:

  • 高平做网站免费游戏打开就能玩
  • 苏州智能网站开发营口网站开发
  • 泰安网网站建设西安网站建设方案托管
  • 中国电商公司100排名赣州seo推广
  • 安卓app安装河北seo推广平台
  • 自助建网站平台密云广州网站建设
  • 宜昌市夷陵区建设局网站布展设计收费标准
  • 代做网站南京 电子商务网站
  • 接单子做网站男女做那个网站动态图片
  • 乔拓云智能建站官网登录入口广州公司官网搭建
  • 新手学做百度联盟网站有哪些可以做图的网站啊
  • 网站建设完成后如何备案中高端社交网站建设服务商
  • 大型门户网站建设步骤珠海网站制作设计方案
  • 门户网站wordpress哪个比较好百度权重10的网站
  • 浅绿色网站模板建e网室内设计网官网下载
  • 网站设计深圳网站开发小组总结报告
  • 一般网站建设大概需要多少钱手机版企业网站h5
  • 北京网站建设华网天下科技公司湛江网页定制
  • 哪些网站是响应式的网站建设研究
  • 连云港建设网站公司揭阳网站制作怎样
  • 二级网站建设方案 试行如何查看网站备案
  • 用wordpress建一个网站正保建设教育网站
  • asp做网站好不好dede采集规则下载网站
  • 上海十大网站排名商城官方平台入口
  • 朋友做的网站图片不显示不出来wordpress 导入 微信
  • 打开网站自动跳转代码app推广软件
  • 中山哪里可以做网站天津百度推广公司电话
  • 彩网站开发做那个的网站谁有
  • 百度网站打不开蚂蚁币是什么网站建设
  • 唯品会网站开发wordpress安装点提交无法访问