力扣-数据结构-19【算法学习day.90】

前言

###我做这类文章一个重要的目的还是给正在学习的大家提供方向(例如想要掌握基础用法,该刷哪些题?建议灵神的题单和代码随想录)和记录自己的学习过程,我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!


习题

1.具有所有最深节点的最小子树

题目链接: 865. 具有所有最深节点的最小子树 - 力扣(LeetCode)

题面:

代码:

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    TreeNode ans;
    int maxdep = 0;
    int count = 0;
    public TreeNode subtreeWithAllDeepest(TreeNode root) {
        ans = root;
        recursion2(root,0);
        recursion3(root,0);
        recursion(root,0);
        return ans;
    }
    public int recursion(TreeNode node,int u){
        if(node.left==null&&node.right==null){
            if(u==maxdep)return 1;
            return 0;
        }
        int l = 0;
        int r = 0;
        if(node.left!=null){
            l = recursion(node.left,u+1);
        }
        if(node.right!=null){
            r = recursion(node.right,u+1);
        }
        int sum = l+r;
        if(sum==count){
           if(count==1){
            if(l==1){
                ans = node.left;
            }else{
                ans = node.right;
            }
            return 999;
           }else{
            ans = node;
            return 999;
           }
        }
        return l+r;
    }

     public void recursion3(TreeNode node,int u){
        if(node.left==null&&node.right==null){
            if(u==maxdep)count++;
        }
        if(node.left!=null){
            recursion3(node.left,u+1);
        }
        if(node.right!=null){
            recursion3(node.right,u+1);
        }
    }

    public void recursion2(TreeNode node,int u){
        if(node.left==null&&node.right==null){
            if(u>maxdep)maxdep = u;
        }
        if(node.left!=null){
            recursion2(node.left,u+1);
        }
        if(node.right!=null){
            recursion2(node.right,u+1);
        }
    }
}

后言

上面是数据结构相关的习题,下一篇文章会将其他相关的习题。

相关推荐
Sylvia-girl3 小时前
Java——抽象类
java·开发语言
Touper.6 小时前
Redis 基础详细介绍(Redis简单介绍,命令行客户端,Redis 命令,Java客户端)
java·数据库·redis
西西西仓鼠6 小时前
python学习打卡:DAY 40 训练和测试的规范写法
学习
m0_535064606 小时前
C++模版编程:类模版与继承
java·jvm·c++
Magnetic_h6 小时前
【iOS】方法与消息底层分析
笔记·学习·macos·ios·objective-c·cocoa
今天背单词了吗9806 小时前
算法学习笔记:19.牛顿迭代法——从原理到实战,涵盖 LeetCode 与考研 408 例题
笔记·学习·算法·牛顿迭代法
没书读了6 小时前
考研复习-数据结构-第六章-图
数据结构
虾条_花吹雪7 小时前
Using Spring for Apache Pulsar:Message Production
java·ai·中间件
tomorrow.hello7 小时前
Java并发测试工具
java·开发语言·测试工具
Moso_Rx7 小时前
javaEE——synchronized关键字
java·java-ee