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

后言

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

相关推荐
故事和你9111 分钟前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
Fcy64839 分钟前
算法基础详解(三)前缀和与差分算法
算法·前缀和·差分
皮皮林55140 分钟前
面试官:ZSet 的底层实现是什么?
java
yangyanping2010840 分钟前
Go语言学习之对象关系映射GORM
jvm·学习·golang
网络工程小王1 小时前
【Transformer架构详解】(学习笔记)
笔记·学习
kvo7f2JTy1 小时前
基于机器学习算法的web入侵检测系统设计与实现
前端·算法·机器学习
码云数智-大飞1 小时前
C++ RAII机制:资源管理的“自动化”哲学
java·服务器·php
2601_949816581 小时前
Spring+Quartz实现定时任务的配置方法
java
List<String> error_P1 小时前
蓝桥杯最后几天冲刺:暴力大法(一)
算法·职场和发展·蓝桥杯
计算机毕设指导62 小时前
基于SpringBoot校园学生健康监测管理系统【源码文末联系】
java·spring boot·后端·spring·tomcat·maven·intellij-idea