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);//搜索右子树 
	
}
相关推荐
TracyCoder1232 小时前
LeetCode Hot100(25/100)——2. 两数相加(链表)
算法·leetcode·链表
long3162 小时前
Z算法(线性时间模式搜索算法)
java·数据结构·spring boot·后端·算法·排序算法
望未来无悔2 小时前
系统学习算法 专题十九 优先级队列(堆)
java·算法
啊阿狸不会拉杆2 小时前
《机器学习导论》第3章 -贝叶斯决策理论
人工智能·python·算法·机器学习·numpy·深度优先·贝叶斯决策理论
阿蔹2 小时前
力扣面试题二Python
python·算法·leetcode·职场和发展
jaysee-sjc2 小时前
【项目二】用GUI编程实现石头迷阵游戏
java·开发语言·算法·游戏
元亓亓亓2 小时前
LeetCode热题100--169. 多数元素--简单
算法·leetcode·职场和发展
闲人不梦卿2 小时前
算法的特性
算法
Z9fish2 小时前
sse哈工大C语言编程练习22
c语言·开发语言·算法