【无标题】1302 层数最深叶子节点的和

今天还挺难过,学了这么久的树,递归的题还是有问题,我什么时候才能明白呀,有时候感觉自己不适合学习,不适合学计算机。

复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
  //先定义最大深度
  int max1;
  void depthmax(TreeNode* root,int dep){
    if(root==NULL){
        return ;
    }
    if(dep>max1){
        max1=dep;
    }
    if(root->left!=NULL){
    depthmax(root->left,dep+1);
    }
    if(root->right!=NULL){
    depthmax(root->right,dep+1);
    }
  }

  int sumdepthmax(TreeNode *root,int dep){
    if(root==NULL){
        return 0;
    }
    if(dep==max1){
    return root->val;
    }
    int suml=sumdepthmax(root->left,dep+1);
    int sumr=sumdepthmax(root->right,dep+1);
    return suml+sumr;
  }
public:
    int deepestLeavesSum(TreeNode* root) {
    max1=0;
    depthmax(root,0);
    return sumdepthmax(root,0);
    }
};

这个题首先要两个函数,一个函数来求最大深度,我做第二遍的时候感觉思路很模糊,就是因为我没有想到先定义一个最大深度,然后再不断更新最大深度的值,如果左子树的深度大于最大深度,我们就将最大深度的值替换,右子树也一样。

第二个函数是求和函数,首先我的递归出口的条件错了,我的判断是假如左子树和右子树均为空的时候,这样反而会漏了最大深度,因为这样做相当于只要是没有孩子节点,就返回0,而我们要的是最大深度的节点,正确的应该是当此节点为空的时候,我们返回0,

相关推荐
TechPioneer_lp几秒前
就业指导|中九非科班毕业,华为 OD 做 Java 后端想转 C++,能找到深度学习挂钩的岗工作吗?
java·c++·华为od·华为·就业指导·校招指导
Dicky-_-zhang6 分钟前
分布式ID生成方案详解与实战
java·jvm
m0_474606787 分钟前
JAVA - 使用Apache POI 自定义报表字段手写导出(支持-合并单元格)
java·开发语言·apache
城事漫游Molly8 分钟前
AI 快速生成标准化问卷分析报告:从 SUS 到 UMUX-LITE,如何把“分数”写成“结论”
人工智能·算法·机器学习·论文笔记·科研统计·问卷设计
zhz52148 分钟前
Spring Boot 接入国密实战:传输加密(TLCP)+ 密码加密(SM4)
java·spring boot·后端·国密·sm4
人道领域12 分钟前
【LeetCode刷题日记】617.合并二叉树(空间换安全,还是原地省内存)
java·数据结构·算法·leetcode
独自破碎E16 分钟前
机器人Java后端算法笔试题解析
java·windows·算法
我是一颗柠檬16 分钟前
【JDK8新特性】函数式接口Day2
java·开发语言·后端·intellij-idea
Bat U17 分钟前
JavaEE|JVM
java·jvm·java-ee
运筹vivo@19 分钟前
3043. 最长公共前缀的长度(Leetcode 每日一题)
c++·算法·leetcode·职场和发展·每日一题