news 2026/5/13 11:58:52

P4913 【深基16.例3】二叉树深度 dfs-二叉树的遍历

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
P4913 【深基16.例3】二叉树深度 dfs-二叉树的遍历

P4913 【深基16.例3】二叉树深度
来源:

文章目录

    • 题目
    • 思路
    • 参考代码

题目

思路

从根节点开始往下搜索到叶子结点每一种可能的路径,然后找到长度最长的路径长度即为深度-即遍历这棵树

  1. 如何储存该图,每个结点给出孩子节点,因此可以直接结构体储存孩子节点,结构体的下标就为该节点的序号
  2. 如何从根节点开始搜索,直接从根节点开始玩往下搜索其孩子结点(先递归遍历该节点的左节点,再递归遍历该节点的右节点。),并及时记录本次搜索所在的路径长度(深度)- 搜完求最大值即为结果
  3. 递归搜索-dfs退出条件:搜到叶子结点位置return

因为每个节点遍历一次,所以总时间复杂度为O(n) 运行时间安全

参考代码

#include<bits/stdc++.h>usingnamespacestd;constintN=1e6+5;intans=1;structnode{intl;intr;}tree[N];voiddfs(intx,intk);intmain(){intn;cin>>n;for(inti=1;i<=n;i++){cin>>tree[i].l>>tree[i].r;}dfs(1,1);//深搜遍历结点,初始深度为1cout<<ans;return0;}voiddfs(intx,intk){if(x==0){//节点搜索到叶节点则停止return;}ans=max(ans,k);dfs(tree[x].l,k+1);//搜索左子树dfs(tree[x].r,k+1);//搜索右子树}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 12:05:08

Kotlin编程语言入门与常见问题

麻烦点赞&#xff1a; https://t.csdn.cn/ThlhE 谢谢&#xff01;接下来&#xff0c;正片开始。 Kotlin是一种具有显著特性的编程语言&#xff0c;新手入门可先了解其入门知识&#xff0c;以及新手可能遇到的常见问题。 入门知识 与Java的关系&#xff1a;Kotlin与Java语言具…

作者头像 李华
网站建设 2026/5/10 21:33:42

三角形正反面之谜:三个点如何决定朝向?

你在做 3D 的时候,迟早会遇到一个“灵异事件”: 模型明明在眼前,结果转个角度它就消失了 开了背面剔除(Backface Culling),模型像被削了一层皮 做了镜像(Scale = -1),整个模型忽然“里外翻转” 阴影破洞、轮廓闪烁、某些面忽隐忽现 这时候很多人第一反应是:法线坏了?…

作者头像 李华
网站建设 2026/5/9 0:12:17

同花顺 app 设置技巧

自选分添加&#xff0c;是在右下就 同顺商城里面设置&#xff0c;搜索添加横屏日线操作&#xff1a;长按是日线游走。否则是日线时间滑动。

作者头像 李华