代码随想录训练营第十七天|110.平衡二叉树 ● 257. 二叉树的所有路径 ● 404.左叶子之和

news2024/12/29 10:06:00

110.平衡二叉树

看完题后的思路

在这里插入图片描述

  1. int[] f(root)
  2. if root=null return [true,0]
  3. left[]=f(root.left)
    if(!left[0]){return [false,-1]}
    right[]=f(root.right)
    if(!right[0]){return [false,-1]}
    return[true,math.max(left[1],right[1])+1]

思路

上面的过程弄复杂了,其实直接返回高度即可,如果子树是平衡二叉树,返回树的高度,如果不是,返回-1.

代码

 // 110. 平衡二叉树
        public boolean isBalanced(TreeNode root) {
            Object[] objects = isBalanced02(root);
            return (Boolean) objects[0];
        }
        public Object[] isBalanced02(TreeNode root) {
            if (root==null){
                return new Object[]{true,0};
            }
            Object[] left = isBalanced02(root.left);
            if (!(Boolean) left[0]){
                return new Object[]{false,0};
            }
            Object[] right = isBalanced02(root.right);
            if (!(Boolean)right[0]){
                return new Object[]{false,0};
            }
              Integer leftHeight = (Integer) left[1];
            Integer rightHeight = (Integer) right[1];
            if (Math.abs(leftHeight-rightHeight)<=1){
                return new Object[]{true,Math.max((Integer)left[1],(Integer) right[1])+1};
            }else {
                return new Object[]{false,-1};
            }
        }

复杂度

在这里插入图片描述

收获

本题回溯做法可以大框架使用后续迭代,然后求每个节点的高度,效率很低
三刷大脑过一遍

257. 二叉树的所有路径

看完题后的思路

本题本质是回溯算法

  1. 递归参数
    是指一个全局变量
    void f(root,Stringbuild path)
  2. 终止条件
    if root==nul 将处理后的path加入list,return
  3. 递归
    终止判断
    path.add(root)
    f(root.left,path);
    f(root.right,payh);
    // 回溯
    path.remove(root)
    错误,看代码

代码

 ArrayList<String> binaryTreePathsRes = new ArrayList<>();
        public List<String> binaryTreePaths(TreeNode root) {
        
            binaryTreePathsBT(root,new StringBuilder());
            return binaryTreePathsRes;
        }
    public void binaryTreePathsBT(TreeNode root,StringBuilder sb) {
        sb.append(root.val);
        sb.append("->");
        if (root.left==null&&root.right==null){
            //sb.delete(sb.length()-1,sb.length());
            //binaryTreePathsRes.add(sb.toString());
             String string = sb.toString();
            
            binaryTreePathsRes.add(string);
            return;
        }
      
       if (root.left!=null){
            binaryTreePathsBT(root.left,sb);
            sb.delete(sb.length()-3,sb.length());
        }
       
        if (root.right!=null){
            binaryTreePathsBT(root.right,sb);
            sb.delete(sb.length()-3,sb.length());
        }
    }

代码有点小问题,使用sb删除的时候是按字符删,引文数字位数不同,所以不知道删除几个

收获

当终止条件是叶子节点的时候,需要首先加入叶子节点
每次执行完都要回溯,删除的是子节点,不是自己,最终这种模式最终会剩下根节点
三刷敲一遍

404.左叶子之和

在这里插入图片描述

看完题后的思路

使用前序遍历

 int sumOfLeftLeavesRes=0;
      public void sumofleftleaves(TreeNode root,TreeNode pre) {
        if (root==null){
            return;
        }
        if (root.left==null&&root.right==null&&pre.left==root){
            sumOfLeftLeavesRes+=root.val;
        }
        sumofleftleaves(root.left,root);
        sumofleftleaves(root.right,root);

    }
    public int sumOfLeftLeaves(TreeNode root) {
        // 特殊条件判断
          if (root==null||(root.left==null&&root.right==null)){
            return 0;
        }
        // TreeNode iroot = new TreeNode();
        // iroot.left=root;
        sumofleftleaves(root,null);
        return sumOfLeftLeavesRes;
    }

复杂度

在这里插入图片描述

收获

本题有前序前一个节点代码
本题三刷要看一遍
本题后续也可以,三刷再来看

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/189910.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Elasticsearch 入门到精通-Elasticsearch核心倒排索引数据结构

Elasticsearch 简介Elasticsearch 是一个分布式、高扩展、高实时的搜索与数据分析引擎。Elasticsearch 建立在全文搜索引擎 Apache Lucene™ 基础上&#xff0c;通过 Lucene 的倒排索引技术实现比关系型数据库更快的过滤&#xff0c;从而很方便的使大量数据具有搜索、分析和探索…

vue插槽之插槽的用法及作用域插槽详解

目录前言一&#xff0c;插槽的基本使用1.1 引出插槽1.2 插槽的基本使用1.3 默认插槽1.4 插槽样式二&#xff0c;具名插槽2.1 引出具名插槽2.2 具名插槽的使用三&#xff0c;template标签3.1 引出template标签3.2 template标签的使用四&#xff0c;作用域插槽4.1 引出作用域插槽…

C语言小题,有3个学生的信息,放在结构体数组中,要求输出全部学生的信息。(指向结构体数组的指针)

前言&#xff1a; 此篇是针对 指向结构体数组的指针 方面的练习。 解题思路&#xff1a; 用指向结构体变量的指针来处理&#xff1a; &#xff08;1&#xff09;声明结构体类型 struct Student &#xff0c;并定义结构体数组&#xff0c;同时使之初始化&#xff1b; &#xff…

【Rust】9. 常见集合

9.1 Vector 9.1.1 创建 vector vector 只能储存相同类型的值&#xff01;创建空的 vector&#xff1a;Vec::new()创建有值的 vector&#xff1a;vec! 宏 9.1.2 向 vector 中添加元素 9.1.3 读取 vector 的元素 索引语法&#xff1a;当引用一个不存在的元素时 Rust 会造成 pa…

设计模式-软件设计原则

目录 3.软件设计原则 3.1 开闭原则 3.2 里氏代换原则 3.3 依赖倒转原则 3.4 接口隔离原则 3.5 迪米特法则 3.6 合成复用原则 3.软件设计原则 在软件开发中&#xff0c;为了提高软件系统的可维护性和可复用性&#xff0c;增加软件的可扩展性和灵活性&#xff0c;程序员要…

【QT5 定时器练习-笔记-样例讲解-实现方式>>>(1)定时器事件方式和(2)定时器绑定函数】

QT5 -定时器简单应用-样例讲解-实现方式1-定时器事件方式1、前言2、实验环境3、定时器实现方式说明-以及效果3、操作步骤-&#xff08;1&#xff09;定时器事件方式&#xff08;1&#xff09;建立工程&#xff08;2&#xff09;拉控件布局&#xff08;3&#xff09;代码部分编写…

《深入浅出计算机组成原理》学习笔记 Day16

冒险和预测&#xff08;一&#xff09;1. 超长流水线的缺点2. 冒险和分支预测参考1. 超长流水线的缺点 增加流水线的深度&#xff0c;在同主频下&#xff0c;其实就是降低了 CPU 的性能。 一个 Pipeline Stage&#xff0c;就需要一个时钟周期。如果我们把任务分成 31 个阶段&…

2014年408专业算法题

文章目录0 结果1 题目2 思路附录0 结果 1 题目 2 思路 二叉树的带权路径长度&#xff08;WPL&#xff09;的计算方法有两种&#xff1a; 1&#xff0c;定义&#xff1a;WPL所有叶结点的权值Wi∗该结点深度Di求和WPL所有叶结点的权值W_i*该结点深度D_i求和WPL所有叶结点的权值…

如何管理IC研发过程产生的bug

一款芯片的研发过程中总是伴随着bug、bug和bug&#xff0c;研发线上各端的IC工程师也是全程在debug、debug和debug&#xff0c;直到最终的GDSII文件交给Founry工厂加工&#xff0c;全程都是为了保证芯片最终能够安全保质的tape-out成功。由此可见&#xff0c;bug的跟踪管理是至…

【数据结构】题解:二叉树的非递归遍历

【数据结构】题解&#xff1a;二叉树的非递归实现 文章目录【数据结构】题解&#xff1a;二叉树的非递归实现一、问题描述二、递归实现三、非递归实现3.1 前序遍历3.2 中序遍历3.3 后序遍历一、问题描述 二叉树的前序遍历&#xff0c;非递归迭代实现 &#xff0c;二叉树的前序遍…

Synology群晖小技巧之百度网盘远程下载同步

&#x1f388; 作者&#xff1a;互联网-小啊宇 &#x1f388; 简介&#xff1a; CSDN 运维领域创作者、阿里云专家博主。目前从事 Kubernetes运维相关工作&#xff0c;擅长Linux系统运维、开源监控软件维护、Kubernetes容器技术、CI/CD持续集成、自动化运维、开源软件部署维护…

[HCTF 2018]WarmUp1

http://ca039961-2ebb-4acd-8107-ece077539106.node4.buuoj.cn:81/ 按F12查看源码 根据提示访问source.php 分析源码&#xff0c;搞懂其中几个函数 mb_strpos() &#xff1a;返回要查找的字符串在要检查的字符串中首次出现的位置 mb_strpos (haystack ,needle) //haystack&…

AVS3变换系数编码:SRCC

AVS3摒弃了HEVC和AVS2中的基于CG(Coefficient Group)的变换系数编码方式&#xff0c;使用基于扫描区域的变换系数编码方法Scan Region-based Coefficient Coding(SRCC)。在基于块的预测变换混合编码框架里&#xff0c;当一个块完成预测、变换和量化后会获得相应的变换系数&…

盘点2022十大热门编程语言(上)

全球知名代码托管平台 GitHub发布的2022年GitHub Octoverse年度报告公布了全球最流行的十大编程语言&#xff0c;其中JavaScript蝉联第一&#xff0c;Python位列次席。 编程是技术革新的核心&#xff0c;对于所有的编程开发人员来说&#xff0c;对世界范围内编程语言发展和趋势…

APP UI自动化测试思路总结

pythonappium自动化测试系列就要告一段落了&#xff0c;本篇博客咱们做个小结。 首先想要说明一下&#xff0c;APP自动化测试可能很多公司不用&#xff0c;但也是大部分自动化测试工程师、高级测试工程师岗位招聘信息上要求的&#xff0c;所以为了更好的待遇&#xff0c;我们还…

算法该不该刷?如何高效刷算法?

一、算法该不该刷&#xff1f;最近有小伙伴向我咨询一个问题&#xff0c;就是算法该不该刷&#xff0c;该如何刷算法呢&#xff1f;这个问题可谓太大众化了&#xff0c;只要你去某乎、某度搜索一下相关的解答&#xff0c;会有无数种回答&#xff0c;可见这个问题困扰了多少学习…

Ruoyi-Cloud框架学习-【08 前端、后端服务打包】

后端打包部署 在ruoyi项目的bin目录下执行package.bat打包Web工程&#xff0c;生成war/jar包文件。 然后会在各个项目下生成target文件夹、包含war或jar 提示 不同模块版本会生成在ruoyi/ruoyi-xxxx模块下target文件夹 部署工程文件 1、jar部署方式 使用命令行执行&#xf…

docker学习(三):docker镜像分层原理及本地镜像推送到阿里云或私服

文章目录前言docker镜像分层加载原理docker镜像commit操作产生新镜像本地镜像发布到阿里云将本地镜像推送到私有库前言 大家好&#xff0c;这是我学习docker系列的笔记文章&#xff0c;目标是掌握docker,为后续学习K8s做准备。本文记录了docker镜像分层加载的原理&#xff0c;…

DSP_TMS320F28377D_使用定时器实现<获取代码块运算时间>的功能

前言 给大家拜个晚年&#xff0c;此博客是2023年的第一篇博客&#xff0c;希望在2023年我与各位大佬共同进步。以前在STM32上实现过相关的功能&#xff0c;链接如下&#xff1a; STM32_使用定时器实现&#xff1c;获取代码块运算时间&#xff1e;的功能_江湖上都叫我秋博的博…

发表计算机 SCI 论文有多难? - 易智编译EaseEditing

发表SCI论文的对本科生来说点难度&#xff0c;一般论文的水平是这样&#xff1a;普刊&#xff1c;核心&#xff1c;SCI。 不同的专业都可以发SCI&#xff0c;只是影响因子高低不用而已&#xff0c;有的领域分值高&#xff0c;有的偏低。 就是说不同领域SCI期刊&#xff0c;影响…