本篇接着《LeetCode刷题总结-树篇(上)》,讲解有关树的类型相关考点的习题,本期共收录17道题,1道简单题,10道中等题,6道困难题。

在LeetCode题库中,考察到的不同种类的树有七种,分别是二叉搜索树、平衡二叉树、满二叉树、完全二叉树、线段树、字典树和树状数组。每一种类型的树,有着不同的特性以及对应的考察重点。考察重点可参考下图,下文按照树的类型分别划分了一个目录章节,并给出了对应的经典习题。

1 二叉树搜索树

基本定义:又称二叉查找树,二叉排序树。若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值; 它的左、右子树也分别为二叉搜索树。参考示例图如下(图片来源):

考察重点:二叉搜索树的创建问题、删除二叉树的指定节点、修改二叉树节点的值、添加节点。

由于二搜索树自身的特殊性质,可知插入和查找具体节点的时间复杂度为O(logn)。另外,需要谨记应用中序遍历二叉搜索树得到的序列为升序序列。对于添加、修改二叉树的节点问题,中序遍历的思想一般能够提供较好的解答思路。

本部分收录的习题(下面出现的数字为对应题目在LeetCode题库中的序号),具体如下:

95.不同的二叉搜索树 II,难度:中等(考察搜索二叉树的创建问题)

99.恢复二叉搜索树,难度:困难 (考察搜索二叉树修改节点的问题)

450.删除二叉搜索树中的节点,难度:中等(考察搜索二叉树节点删除问题)

701.二叉搜索树中的插入,难度:中等(考察搜索二叉树节点的插入问题)

对于上述四类考点,应用Java实现删除二叉搜索树中节点时,由于采用递归的解法,需要特别注意深拷贝和浅拷贝的问题。另外,对于删除操作可以采用地址覆盖的操作来实现,此部分的操作代码可以作为模板记住。下面具体给出题号为450题目的描述及解答代码。

题目描述:

解答代码:

class Solution {
public TreeNode deleteNode(TreeNode root, int key) {
if (root == null)
return null;
if (key < root.val) { // 待删除节点在左子树中
root.left = deleteNode(root.left, key);
return root;
} else if (key > root.val) { // 待删除节点在右子树中
root.right = deleteNode(root.right, key);
return root;
} else { // key == root.val,root 为待删除节点
if (root.left == null) // 返回右子树作为新的根
return root.right;
else if (root.right == null) // 返回左子树作为新的根
return root.left;
else { // 左右子树都存在,返回后继节点(右子树最左叶子)作为新的根
TreeNode successor = min(root.right);
successor.right = deleteMin(root.right);
successor.left = root.left;
return successor;
}
}
} private TreeNode min(TreeNode node) {
if (node.left == null)
return node;
return min(node.left);
} private TreeNode deleteMin(TreeNode node) {
if (node.left == null)
return node.right;
node.left = deleteMin(node.left);
return node;
}
}

2 平衡二叉树

基本定义:它是一棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树。参考示例图如下(图片来源

考察重点:给定一棵二叉树,检测该树是否为平衡二叉树。即考察我们递归遍历树的每个节点,检测每个节点对应的左右子树的高度差是否不大于1。

本部分收录的习题:

110.平衡二叉树,难度:简单

3 满二叉树

基本定义:每个结点恰好有 0 或 2 个子结点。

考察重点:给定若干个元素,求能够组成的不同满二叉树的个数。

本部分收录的习题:

894.所有可能的满二叉树,难度:中等

4 完全二叉树

基本定义:完全二叉树从根结点到倒数第二层满足完美二叉树,最后一层可以不完全填充,其叶子结点都靠左对齐。(附完美二叉树定义:一个深度为k(>=-1)且有2^(k+1) - 1个结点的二叉树称为完美二叉树。)参考示例图如下(图片来源):

考察重点:统计给定树的节点个数、创建完全二叉树以及检测给定树是否为完成二叉树。

本部分收录的习题:

222.完全二叉树的节点个数,难度:中等(考察统计节点个数)

919.完全二叉树插入器,难度:中等(考察创建完全二叉树)

958.二叉树的完全性检验,难度:中等(考察检测是否为完全二叉树)

5 线段树

基本定义:线段树是一种二叉搜索树,与区间树相似,它将一个区间划分成一些单元区间,每个单元区间对应线段树中的一个叶结点。参考示例图如下(图片来源):

实际应用:使用线段树可以快速的查找某一个节点在若干条线段中出现的次数,时间复杂度为O(logN)。

考察重点:给定问题,灵活转换为线段树求解。

应用Java语言创建线段树时,可以借助内置的TreeSet和TreeMap数据结构。TreeSet是HashSet的升级版,TreeMap则是HashMap的升级版

本部分收录的习题:

715. Range模块,难度:困难(可以采用TreeSet构建线段树,需要熟悉TreeSet在Java中相关接口的用法)

732.我的日程安排表III ,难度:困难 (可以采用TreeMap构建模拟化线段树,需要熟悉TreeMap在Java中相关接口的用法)

850.矩形面积II,难度:困难(考察定义线段树的标准解法)

6 字典树

基本定义(百度百科):又称单词查找树、前缀树、Trie树,是一种树形结构,是一种哈希树的变种。典型应用是用于统计,排序和保存大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计。它的优点是:利用字符串的公共前缀来减少查询时间,最大限度地减少无谓的字符串比较,查询效率比哈希树高。参考示例图如下(图片来源):

考察重点:创建字典树、单词搜索。

本部分收录的习题:

208.实现Trie(前缀树),难度:中等(考察创建字典树)

212.单词搜索II,难度:困难(考察单词搜索)

648.单词替换,难度:中等(考察单词搜索)

7 树状数组

基本定义(百度百科):是一个查询和修改复杂度都为log(n)的数据结构。主要用于查询任意两位之间的所有元素之和,但是每次只能修改一个元素的值;经过简单修改可以在log(n)的复杂度下进行范围修改,但是这时只能查询其中一个元素的值(如果加入多个辅助数组则可以实现区间修改与区间查询)。参考示例图如下(图片来源):

考察重点:构建树状数组。

本部分收录的习题:

307.区域和检索-数组可修改,难度:中等

315.计算右侧小于当前元素的个数,难度:困难

LeetCode刷题总结-树篇(中)的更多相关文章

  1. LeetCode刷题总结-树篇(下)

    本文讲解有关树的习题中子树问题和新概念定义问题,也是有关树习题的最后一篇总结.前两篇请参考: LeetCode刷题总结-树篇(上) LeetCode刷题总结-树篇(中) 本文共收录9道题,7道中等题, ...

  2. LeetCode刷题总结-树篇(上)

          引子:刷题的过程可能是枯燥的,但程序员们的日常确不乏趣味.分享一则LeetCode上名为<打家劫舍 |||>题目的评论: 如有兴趣可以从此题为起点,去LeetCode开启刷题之 ...

  3. LeetCode刷题总结-数组篇(中)

    本文接着上一篇文章<LeetCode刷题总结-数组篇(上)>,继续讲第二个常考问题:矩阵问题. 矩阵也可以称为二维数组.在LeetCode相关习题中,作者总结发现主要考点有:矩阵元素的遍历 ...

  4. C#LeetCode刷题-字典树

    字典树篇 # 题名 刷题 通过率 难度 208 实现 Trie (前缀树)   48.6% 中等 211 添加与搜索单词 - 数据结构设计   39.9% 中等 212 单词搜索 II   27.9% ...

  5. LeetCode刷题总结-数组篇(上)

    数组是算法中最常用的一种数据结构,也是面试中最常考的考点.在LeetCode题库中,标记为数组类型的习题到目前为止,已累计到了202题.然而,这202道习题并不是每道题只标记为数组一个考点,大部分习题 ...

  6. LeetCode刷题总结-数组篇(下)

    本期讲O(n)类型问题,共14题.3道简单题,9道中等题,2道困难题.数组篇共归纳总结了50题,本篇是数组篇的最后一篇.其他三个篇章可参考: LeetCode刷题总结-数组篇(上),子数组问题(共17 ...

  7. LeetCode刷题专栏第一篇--思维导图&时间安排

    昨天是元宵节,过完元宵节相当于这个年正式过完了.不知道大家有没有投入继续投入紧张的学习工作中.年前我想开一个Leetcode刷题专栏,于是发了一个投票想了解大家的需求征集意见.投票于2019年2月1日 ...

  8. C#LeetCode刷题-线段树

    线段树篇 # 题名 刷题 通过率 难度 218 天际线问题   32.7% 困难 307 区域和检索 - 数组可修改   42.3% 中等 315 计算右侧小于当前元素的个数   31.9% 困难 4 ...

  9. LeetCode刷题总结-动态规划篇

    本文总结LeetCode上有动态规划的算法题,推荐刷题总数为54道.具体考点分析如下图: 1.中心扩展法 题号:132. 分割回文串 II,难度困难 2.背包问题 题号:140. 单词拆分 II,难度 ...

随机推荐

  1. Java Import的使用

    这里根据上一篇中ClassObject.java的例子改编的:https://www.cnblogs.com/jizizh/p/11938574.html 一.创建ClassObjectImport. ...

  2. 【Luogu P2563】【集训Day 4 动态规划】质数和分解

    题目链接:Luogu P2563 质数和分解(prime) [问题描述] 任何大于 1 的自然数 N,都可以写成若干个大于等于2且小于等于 N 的质数之和表达式(包括只有一个数构成的和表达式的情况), ...

  3. <<代码大全>>阅读笔记之一 使用变量的一般事项

    一.使用变量的一般事项 1.把变量引用局部化 变量应用局部化就是把变量的引用点尽可能集中在一起,这样做的目的是增加代码的可读性 衡量不同引用点靠近程度的一种方法是计算该变量的跨度(span) 示例 a ...

  4. day 36 初始前端 html语言

    参考博客https://www.cnblogs.com/majj/p/9056951.html进行学习 html标签 特征: .空白折叠现象 .对空格和换行不敏感 .标签要严格封闭 p标签的嵌套 多注 ...

  5. 解密面试中的套路,你都get到了么?

    如果大家有关注一些测试类的公众号或者论坛的话,肯定会发现很多文章都在表示现在行业的寒冬冷潮来了!然后有很多测试行业从业者,或者转行测试行业者都表示:工作好难找,公司跑了千千万,依然拿不到一个offer ...

  6. All-in-one 的Serving分析

    export_func.export(model, sess, signature_name=mission, version=fold + 1) def export(model, sess, si ...

  7. word2vec:CBOW和skip-gram模型

    1.CBOW模型 之前已经解释过,无论是CBOW模型还是skip-gram模型,都是以Huffman树作为基础的.值得注意的是,Huffman树中非叶节点存储的中间向量的初始化值是零向量,而叶节点对应 ...

  8. 【新手向】如何学习Java集合

    前言 只有光头才能变强. 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 如果认识我的同学可能就知道,我已经写过很多系列级 ...

  9. js前端数据验证JS工具

    var regexEnum = { intege : "^-?[1-9]\\d*$", // 整数 intege1 : "^[1-9]\\d*$", // 正整 ...

  10. MySQL 8.0新增特性详解【华为云技术分享】

    版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/devcloud/article/detai ...