408数据结构真题2014-41

举报
辰chen 发表于 2022/06/16 22:10:43 2022/06/16
【摘要】 文章目录 题目AC代码 题目 本题链接:AcWing 3766. 二叉树的带权路径长度 注:链接题目仅代表和本题大体相似 因为是考研笔试,本题代码以C语言去写 AC代码 代码解...

文章目录


题目

本题链接:AcWing 3766. 二叉树的带权路径长度
在这里插入图片描述

注:链接题目仅代表和本题大体相似
因为是考研笔试,本题代码以C语言去写

AC代码

代码解释:本题要求的是带权路径的长度之和,带权路径的长度 = 权值点 * 该点到根节点的距离,下面举一个栗子去说明这一点:
在这里插入图片描述
比如栗子中给的这棵树,带权路径的长度之和 = (12 * 1 + 2 * 1 + 6 * 2 + 4 * 2) = 34
题目中要求的是所有叶节点的带权路径之和,故不包含2这个点,答案为:(12 * 1 + 6 * 2 + 4 * 2) = 32,不难看出,本题其实是要求我们遍历这棵树,我们遍历树的方法可以采用dfsbfs两种方法,笔试建议采用dfs的写法,dfs写起来要比bfs精简很多!

代码

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */
 
int dfs(struct TreeNode* root, int depth){
    if (!root) return 0;
    if (!root -> left && !root -> right)
        return root -> val * depth;
    else return dfs(root -> left, depth + 1) + dfs(root -> right, depth + 1);
}
 
int pathSum(struct TreeNode* root) {
    return dfs(root, 0);
}

文章来源: chen-ac.blog.csdn.net,作者:辰chen,版权归原作者所有,如需转载,请联系作者。

原文链接:chen-ac.blog.csdn.net/article/details/121670595

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。