首页 > 其他分享 >刷题总结——树

刷题总结——树

时间:2024-10-24 16:00:35浏览次数:1  
标签:总结 遍历 递归 dfs DFS 返回值 节点 刷题

总结刷题中遇到的与树有关问题

遍历问题

前中后序遍历

  • 有递归与送代两种写法
  • 迭代时需要栈模拟,中序遍历单独注意写法(类似于模拟调用栈),后序遍历可以通过前序遍历+反转的方式实现
题目 LC编号 注意事项
前序 递归 144 正常递归
前序 非递归 144 插入单个root后进行Stack模拟 pop之后插入右左
中序 递归 94 正常递归
中序 非递归 04.06 插入所有left后进行Stack模拟 假设pop的为根节点,插入右和右的所有leftmost节点
后序 递归 145 正常递归
后序 非递归 145 使用前序并且插入顺序变成左右,之后翻转
层序 非递归 102 使用queue容器模拟

步骤

对于遍历类题目,可以按照以下步骤:

  • 要了解所求的答案从哪里来,并将其映射到前中后序遍历和层序遍历中的一种
  • 之后就明确了使用DFS/BFS写法,需要引入哪些额外参数和全局变量:
    • 前序:普通DFS
    • 中序:带有额外input参数(前驱/后继节点)的DFS
    • 后序:带有返回值的DFS,返回值用于根节点相关计算
    • 层序:使用queue模拟实现的BFS

思考

此处引用灵神给的思考题,以及个人的思考

  • 一般来说,DFS 的递归边界是空节点。在什么情况下,要额外把叶子节点作为递归边界?
    • 如果把叶子节点作为递归边界,在写DFS的时候就要check加入的是否为空:
      if (node->left) {
      dfs(node->left, seq);
      }
      if (node->right) {
      dfs(node->right, seq);
      }
    • 有的时候可能要统计的是具体的某种性质的节点(比如左叶子/右叶子),这种情况下可能dfs函数需要使用叶子节点判断,然后进行相应计算
  • 在什么情况下,DFS 需要有返回值?什么情况下不需要有返回值?
    • DFS返回值的作用是用于帮助根节点计算当前节点的结果,即当前目标值计算需要依靠左右子树dfs(root->left), dfs(root->right)各自的DFS返回值,如果不需要则可以不设置返回值
    • 从DFS返回值到当前节点结果计算可以认为是自底向上“归”的过程,相当于后序遍历postorder
  • 在什么情况下,题目更适合用自顶向下的方法解决?什么情况下更适合用自底向上的方法解决?
    • 自顶向下pre-order:划分子问题并代入参数进入下层DFS,之后逐一遍历并且利用全局变量作最大值/最小值统计,dfs函数本身不需要返回值
    • 自底向上post-order:汇总子问题解,得到当前的解,通常无需传入参数
    • 一些复杂的问题,本身属于自底向上的方法,但是还需要通过全局变量来计算结果,即dfs返回的和最终统计结果不一致
  • 在什么情况下,需要设计额外的变量作为DFS递归的额外参数?
    • 有的问题需要在dfs中遍历到每个节点设置状态,并且前一个遍历的节点(前驱)的中间结果需要pass到后继节点使用,这个时候需要设计一些传参用来传递这种信息,通常是中序遍历,比如二叉树转链表/双向链表
    • 自顶向下DFS需要维护统计量(题目298)
    • 自底向上DFS中,其实是返回值代替了需要传下去的统计量,少一个入参多一个出参
    • 这种题目可能还伴随设置dummy头节点的处理,用来简化问题

树型DP问题

树的直径:

  • 注意全局变量ans和dfs返回值不一致的情况,ans计算直径/路径,dfs返回的是深度

  • ans可以用全局变量存储,也可以用引用的形式作为dfs的传入参数

  • 树dp并非具有重叠子问题,而是需要在子节点解决之后利用其状态进行当前节点的决策,这一步骤类似于dp中的状态转移

  • 树dp问题有独立集问题和控制集问题,其实都可以归为子节点到父节点之间的状态转移(选/不选,染色),此时要求dfs返回的结果不是一个变量而是一组状态值,可以利用C++17的结构化绑定简化代码写法

LCA问题

二叉树LCA

一般树LCA

路径问题

结合hash的路径计算

标签:总结,遍历,递归,dfs,DFS,返回值,节点,刷题
From: https://www.cnblogs.com/hesun/p/18499768

相关文章

  • nginx总结
    使用auth_basic控制访问nginx代理的网站,直接访问如果需要添加安全性,如需要输入用户名+密码才能访问页面,可以通过nginx的auth_baisc配置来实现检查htpasswd一般nginx的安装之后会自带或者nginx容器镜像自带root@ea6255db9f51:/config/nginx/site-confs#htpasswdUsage:......
  • 2024-2025-1 20241401 《计算机基础与程序设计》 第五周学习总结
    班级链接2024计算机基础与程序设计作业要求第五周作业作业目标①Pep/9虚拟机②机器语言与汇编语言③算法与伪代码④测试:黑盒,白盒教材学习内容总结《计算机科学概论》第六章计算机操作:介绍了计算机的基本操作,包括机器语言的基本概念。机器语言是由一系......
  • 考前总结与策略提示
    考前总结与策略提示策略提示放轻松,据以往数据考虑,太紧张会大大降低思考效率不要考虑他人的分数或XXX能不能做出来或没做处理会怎样,考场不是拿来写回忆录的,请珍惜你通过训练换来的考试机会。抄dx的当一个思路的混沌程度/实现难度太高的时候,回溯并重新来如果花费时......
  • 2024/10/23 模拟赛总结
    赛时情况以下是赛时写的。14:10好像当\(n\lem\)时的答案是\(2^n\)。14:20当\(m=2\)时,答案的差值是一个等差数列。答案为\(\dfrac{n(n+1)}{2}+1\)。小样例:\(n=4,m=3\)答案为\(15\)。14:50T1不会啊,润。发现如果你会惹老师生气,干脆直接不写。所以变成了选若干科......
  • RabbitMQ总结
    重试机制背景线上的系统(SpringBoot2.2.11,rabbitmq为3.2.0),某一天突然有大量的错误日志写入,进几台服务器的硬盘都写满了。查看日志发现是RabbitMQ的消费者在接收消息消费时,抛出了异常错误,此时会不断重新进入消费重新打印错误日志,循环如此进硬盘写满了。RabbitMQ的消息重试机......
  • 2024.10.23总结+CSP2024前总结
    赛时T1看完一脸懵逼啊,画了好几个立方体,一直觉得切四刀是14块,然后也找不到什么规律,就去看后面的题了,jsy说是15之后还是没想法,只觉着\(7=2^3-1\),\(15=2^4-1\),当\(n<=m\)时是\(2^n\),后来看回来把已知情况全列出来,找到\(f[i][j]=f[i][j-1]+f[i-1][j-1]\)的递推式,写了60pts的,但WA了......
  • leetcode刷题-1581. 进店却未进行过交易的顾客
    链接:1581.进店却未进行过交易的顾客-力扣(LeetCode)前提条件:表:Visits+-------------+---------+|ColumnName|Type|+-------------+---------+|visit_id|int||customer_id|int|+-------------+---------+visit_id是该表中具有唯一值的列。......
  • Springboot知识点总结
    一、传统使用配置文件方式创建Java对象:1、创建一个普通的Maven项目,并加入依赖:<dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>5.3.1</version></dependency>&......
  • 2024年10月23日总结
    今天继续学习了数据库的连接,这是今日总结完成的模版(还有一些地方有问题)packagemapper;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.PreparedStatement;importjava.sql.SQLException;publicclassstudentsystemmapper{Connectionconn=n......
  • Leetcode刷题Python之3185.构成整天的下标对数目II
    提示:直接暴力求解会超过执行时间,因此要考虑其他方法降低复杂度。文章目录问题描述一、示例:二、解题思路1.找余数2.利用哈希表存储余数3.逐步统计配对数代码实现解释代码复杂度分析问题描述给定一个整数数组hours,表示时间,以小时为单位。我们需要找到数组中满......