• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

408数据结构真题2014-41

武飞扬头像
辰chen
帮助1


题目

本题链接: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);
}
学新通

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgfeeac
系列文章
更多 icon
同类精品
更多 icon
继续加载