代码随想录 day21 第六章 二叉树part07

2024-03-14 09:28

本文主要是介绍代码随想录 day21 第六章 二叉树part07,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今日内容

●  530.二叉搜索树的最小绝对差

●  501.二叉搜索树中的众数

●  236. 二叉树的最近公共祖先

详细布置

1. 二叉搜索树的最小绝对差

关联 leetcode 530.二叉搜索树的最小绝对差

  • 思路
    • 直白想法
      • 中序遍历可以得到一个有序节点值序列
        1. 先中序排列二叉树
        2. 暴力找最小差
    • 双指针
      • 中序遍历二叉树+双指针
        • 左【pre】+中【cur】
        • 中【pre】+右【cur】
  • 题解
    • 递归

      func getMinimumDifference(root *TreeNode) int {res := math.MaxIntvar pre *TreeNode = nilvar traversal func(cur *TreeNode)traversal = func(cur *TreeNode) {if cur == nil {return}//左traversal(cur.Left)//中if pre != nil {res = min(res, cur.Val-pre.Val)}pre = cur//中是相对于右而言的pre//右traversal(cur.Right)}traversal(root)return res}
      
    • 迭代

      func getMinimumDifference(root *TreeNode) int {stack := make([]*TreeNode, 0) //存储节点的栈var cur *TreeNode = root      //当前节点指针var pre *TreeNode = nil       //前一个节点的指针res := math.MaxIntfor cur != nil || len(stack) > 0 {if cur != nil { // 指针来访问节点,访问到最底层stack = append(stack, cur) // 将访问的节点放进栈cur = cur.Left             //左} else {cur = stack[len(stack)-1] //取出栈底元素,左左元素stack = stack[:len(stack)-1]if pre != nil {res = min(res, cur.Val-pre.Val)}pre = curcur = cur.Right}}return res
      }
      

2. 二叉搜索树中的众数

关联 leetcode 501.二叉搜索树中的众数

和 530差不多双指针思路,不过 这里涉及到一个很巧妙的代码技巧。

可以先自己做做看,然后看我的视频讲解。

https://programmercarl.com/0501.二叉搜索树中的众数.html

视频讲解:不仅双指针,还有代码技巧可以惊艳到你! | LeetCode:501.二叉搜索树中的众数_哔哩哔哩_bilibili

  • 题解
    • 自己解法

      • 使用一个map来存储 元素出现次数
      /*** Definition for a binary tree node.* type TreeNode struct {*     Val int*     Left *TreeNode*     Right *TreeNode* }*/
      func findMode(root *TreeNode) []int {rets := make([]int, 0)countMap := make(map[int]int)var traversal func(root *TreeNode)traversal = func(root *TreeNode) {if root == nil {return}countMap[root.Val]++if root.Left != nil {traversal(root.Left)}if root.Right != nil {traversal(root.Right)}}traversal(root)maxCount := 0for k, v := range countMap {if v > maxCount {maxCount = vrets = make([]int, 0)rets = append(rets, k)} else if v == maxCount {rets = append(rets, k)}}return rets
      }
      
    • 二叉搜索树一定是中序遍历

      • 遍历得到的二叉树节点一定是有序的
      • 讲解双指针法
      • 和自己的思路不差, 省去了map的使用, 提升效率
      func findMode(root *TreeNode) []int {ret := make([]int, 0)var pre *TreeNode = nilcount := 0maxCount := 0var traversal func(cur *TreeNode)traversal = func(cur *TreeNode) {if cur == nil {return}traversal(cur.Left) //Left/* Middle */if pre == nil {count = 1 //初始化遍历, 首次走到叶子节点} else if pre.Val == cur.Val {count++ //找到重复元素, 当前元素出现次数递加} else {count = 1 //当前元素是新出现的元素, 重置出现次数}pre = cur //将前一个元素指针指向当前元素if count == maxCount {ret = append(ret, cur.Val)}if count > maxCount {maxCount = countret = []int{cur.Val}}traversal(cur.Right) //Right}traversal(root)return ret
      }
      

3. 二叉树的最近公共祖先

关联 leetcode 236. 二叉树的最近公共祖先

  • 思路

    • 题目强调
      • 输入节点的值互不相同
      • p、q节点一定存在于所给二叉树中
        • 一定能找到祖先节点,最终结果一定不是nil
    • 公共祖先
      • 祖先的左、右节点或者它自己分别包含一个指定节点即可
      • 从底向上回溯查找即可
        • 选用后序遍历
          • 先找左、右孩子,再处理父亲节点本身
            • 如果左右子树恰好包含要找的元素,这时的父亲节点就是一个祖先
  • 题解

    func lowestCommonAncestor(root, p, q *TreeNode) *TreeNode {if root == nil {return nil}if root == q || root == p {return root}//左子树left := lowestCommonAncestor(root.Left, p, q)//右子树right := lowestCommonAncestor(root.Right, p, q)//中if left != nil || right != nil {//当前节点的左子树,右子树恰好包含元素,该节点就是最近公共祖先return root}//走到下面就是至少左右有一个是nilif right != nil {//说明目标节点是通过right返回的return right}if left != nil  {//说明目标节点是通过left返回的return left}  return nil}
    

9. 题外话

  1. 求最小公共祖先,需要从底向上遍历,那么二叉树,只能通过后序遍历(即:回溯)实现从底向上的遍历方式。
  2. 在回溯的过程中,必然要遍历整棵二叉树,即使已经找到结果了,依然要把其他节点遍历完,因为要使用递归函数的返回值(也就是代码中的left和right)做逻辑判断。
  3. 要理解如果返回值left为空,right不为空为什么要返回right,为什么可以用返回right传给上一层结果。

这篇关于代码随想录 day21 第六章 二叉树part07的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/807967

相关文章

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

IIS 7.0 及更高版本中的 FTP 状态代码

《IIS7.0及更高版本中的FTP状态代码》本文介绍IIS7.0中的FTP状态代码,方便大家在使用iis中发现ftp的问题... 简介尝试使用 FTP 访问运行 Internet Information Services (IIS) 7.0 或更高版本的服务器上的内容时,IIS 将返回指示响应状态的数字代

MySQL 添加索引5种方式示例详解(实用sql代码)

《MySQL添加索引5种方式示例详解(实用sql代码)》在MySQL数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中,下面给大家分享MySQL添加索引5种方式示例详解(实用sql代码),... 在mysql数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中。索引可以在创建表时定义,也可

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

Python实现一键PDF转Word(附完整代码及详细步骤)

《Python实现一键PDF转Word(附完整代码及详细步骤)》pdf2docx是一个基于Python的第三方库,专门用于将PDF文件转换为可编辑的Word文档,下面我们就来看看如何通过pdf2doc... 目录引言:为什么需要PDF转Word一、pdf2docx介绍1. pdf2docx 是什么2. by

Spring Security介绍及配置实现代码

《SpringSecurity介绍及配置实现代码》SpringSecurity是一个功能强大的Java安全框架,它提供了全面的安全认证(Authentication)和授权(Authorizatio... 目录简介Spring Security配置配置实现代码简介Spring Security是一个功能强

通过cmd获取网卡速率的代码

《通过cmd获取网卡速率的代码》今天从群里看到通过bat获取网卡速率两段代码,感觉还不错,学习bat的朋友可以参考一下... 1、本机有线网卡支持的最高速度:%v%@echo off & setlocal enabledelayedexpansionecho 代码开始echo 65001编码获取: >