首页 > 其他 > 详细

和树有关的一些知识

时间:2020-02-18 23:27:58      阅读:67      评论:0      收藏:0      [点我收藏+]
问树中每个子树的大小:
 
void get_size(int x) {
    siz[x] = 1;
    for (int i = 0;i < vec[x].size();i++) {
        get_size(vec[x][i]);
        siz[x] += siz[vec[x][i]];
    }
}

 

 
问树中每个节点的深度:
 
void get_dep(int x) {
    for (int i = 0;i < vec[x].size();i++) {
        dep[vec[x][i]] = dep[x] + 1;
        get_dep(vec[x][i]);
    }
}

 

问树中每个点子树点权最大:
 
void get_val(int x) {
    val[x] = w[x];
    for (int i = 0;i < vec[i].size();i++) {
        get_val(vec[x][i]);
        val[x] = max(val[x],val[vec[x][i]]);
    }
}

 

和树有关的一些知识

原文:https://www.cnblogs.com/-Ackerman/p/12329181.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!