每日课堂笔记(2026年1月1日)

每日摄影(河南开封清明上河园国际菊花展):


代码(dfs)

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

const int maxn=1e5+10;
int h[maxn],ne[maxn],e[maxn],idx=0;
int n,m,dep[maxn],ans;

void add(int a,int b){
    e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}
//链式前向星

void dfs(int n,int m){
    for(int i=h[n];~i;i=ne[i]){
        int j=e[i];
        if(j==m) continue;
        dep[j]=dep[n]+1;
        ans=max(ans,dep[j]);
        dfs(j,n);
    }
}
//dfs

int main(){
    memset(h,-1,sizeof h);
    //不可省略

    cin>>n>>m;
    for(int i=1;i<n;i++){
        int a,b;
        cin>>a>>b;
        add(a,b),add(b,a);
        //无向图
    }

    dfs(m,-1);
    //dfs(子节点,父节点)
    cout<<ans;
    return 0;
}

/*
in:
5 5
1 2
1 4
1 5
2 3

out:
3
*/

核心代码批注(dfs函数):

|-----------------------------------|---------------------|
| 代码 | 批注 |
| for(int i=h[n];~i;i=ne[i]){} | 遍历所有与n相连的节点(n的子节点) |
| int j=e[i]; | j为本次循环所取的n的子节点 |
| if(j==m) continue; | 判断j是否为n的父节点m(避免死循环) |
| dep[j]=dep[n]+1; | 更新j的深度(为父节点n的深度加1) |
| ans=max(ans,dep[j]); | 更新最大值 |
| dfs(j,n); | 以j为子节点,为n父节点进行递归深搜 |
| | |
| | |

相关链接:

题目代码: AcWing 3699:树的高度 ← dfs+链式前向星-CSDN博客
链式前向星代码: yxc 图示"链式前向星"核心操作_链式前向星图示-CSDN博客
题目链接: 3699. 树的高度 - AcWing题库

相关推荐
2501_926978332 小时前
“LLM的智能本质--AGI的可能路径--人类的意识本质”三者的统一基底(5.0理论解读)
人工智能·经验分享·笔记·深度学习·机器学习·ai写作·agi
لا معنى له2 小时前
WAM与AC-WM:具身智能时代的世界动作模型与动作条件世界模型
人工智能·笔记·学习
Wilber的技术分享4 小时前
【LeetCode高频手撕题 2】面试中常见的手撕算法题(小红书)
笔记·算法·leetcode·面试
愚昧之山绝望之谷开悟之坡4 小时前
合格境外投资者
笔记
寒秋花开曾相惜6 小时前
(学习笔记)3.8 指针运算(3.8.3 嵌套的数组& 3.8.4 定长数组)
java·开发语言·笔记·学习·算法
_李小白7 小时前
【AI大模型学习笔记之平台篇】第五篇:Trae常用模型介绍与性能对比
人工智能·笔记·学习
承渊政道7 小时前
【优选算法】(实战体会位运算的逻辑思维)
数据结构·c++·笔记·学习·算法·leetcode·visual studio
承渊政道7 小时前
【优选算法】(实战推演模拟算法的蕴含深意)
数据结构·c++·笔记·学习·算法·leetcode·排序算法
左左右右左右摇晃8 小时前
系统性能指标与损耗分析
笔记
悠哉悠哉愿意9 小时前
【单片机复习笔记】第十六届省赛复盘
笔记·单片机·嵌入式硬件