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

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

来源:

文章目录

题目

思路

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

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

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

参考代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 1e6+5;
int ans=1; 
struct node{
	int l;
	int r;
} tree[N];
void dfs(int x,int k) ;
int main() {
	int n; 
    cin >> n;
    for(int i=1;i<=n;i++){
    	cin>>tree[i].l>>tree[i].r; 
	}
	dfs(1,1);//深搜遍历结点,初始深度为1 
	cout<<ans; 
    return 0;
}
void dfs(int x,int k) {
	if(x == 0){ //节点搜索到叶节点则停止 
		return ;
	}
	ans=max(ans,k);
	dfs(tree[x].l,k+1);//搜索左子树 
	dfs(tree[x].r,k+1);//搜索右子树 
	
}
相关推荐
Dlrb12113 小时前
C语言-指针三
c语言·算法·指针·const·命令行参数
Tisfy3 小时前
LeetCode 2540.最小公共值:双指针(O(m+n))
算法·leetcode·题解·双指针
IronMurphy3 小时前
【算法四十七】152. 乘积最大子数组
算法
淘矿人4 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
Cosolar5 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
落羽的落羽6 小时前
【算法札记】练习 | Week4
linux·服务器·数据结构·c++·人工智能·算法·动态规划
萑澈7 小时前
算法竞赛入门:C++ STL核心用法与时空复杂度速查手册
数据结构·c++·算法·stl
Godspeed Zhao7 小时前
从零开始学AI16——SVM
算法·机器学习·支持向量机
江屿风7 小时前
C++OJ题经验总结(竞赛)1
开发语言·c++·笔记·算法