力扣-数据结构-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);
        }
    }
}

后言

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

相关推荐
mit6.82430 分钟前
[C# starter-kit] 命令/查询职责分离CQRS | MediatR |
java·数据库·c#
诸神缄默不语1 小时前
Maven用户设置文件(settings.xml)配置指南
xml·java·maven
任子菲阳1 小时前
学Java第三十四天-----抽象类和抽象方法
java·开发语言
学Linux的语莫1 小时前
机器学习数据处理
java·算法·机器学习
找不到、了1 小时前
JVM的即时编译JIT的介绍
java·jvm
逆小舟2 小时前
【C/C++】指针
c语言·c++·笔记·学习
earthzhang20212 小时前
【1007】计算(a+b)×c的值
c语言·开发语言·数据结构·算法·青少年编程
西瓜er2 小时前
JAVA:Spring Boot 集成 FFmpeg 实现多媒体处理
java·spring boot·ffmpeg
你总是一副不开心的样子(´ . .̫ .2 小时前
一、十天速通Java面试(第三天)
java·面试·职场和发展·java面试
迎風吹頭髮2 小时前
UNIX下C语言编程与实践63-UNIX 并发 Socket 编程:非阻塞套接字与轮询模型
java·c语言·unix