文章目录

  • 题目
  • 示例
  • 思路
  • 题解

题目

给你一个 n * n 矩阵 grid ,矩阵由若干 0 和 1 组成。请你用四叉树表示该矩阵 grid 。

你需要返回能表示矩阵的 四叉树 的根结点。

注意,当 isLeaf 为 False 时,你可以把 True 或者 False 赋值给节点,两种值都会被判题机制 接受 。

四叉树数据结构中,每个内部节点只有四个子节点。此外,每个节点都有两个属性:

val:储存叶子结点所代表的区域的值。1 对应 True,0 对应 False;
isLeaf: 当这个节点是一个叶子结点时为 True,如果它有 4 个子节点则为 False 。

class Node {public boolean val;public boolean isLeaf;public Node topLeft;public Node topRight;public Node bottomLeft;public Node bottomRight;
}

我们可以按以下步骤为二维区域构建四叉树:

1、如果当前网格的值相同(即,全为 0 或者全为 1),将 isLeaf 设为 True ,将 val 设为网格相应的值,并将四个子节点都设为 Null 然后停止。

2、如果当前网格的值不同,将 isLeaf 设为 False, 将 val 设为任意值,然后如下图所示,将当前网格划分为四个子网格。

3、使用适当的子网格递归每个子节点。

四叉树格式:

输出为使用层序遍历后四叉树的序列化形式,其中 null 表示路径终止符,其下面不存在节点。

它与二叉树的序列化非常相似。唯一的区别是节点以列表形式表示 [isLeaf, val] 。

如果 isLeaf 或者 val 的值为 True ,则表示它在列表 [isLeaf, val] 中的值为 1 ;如果 isLeaf 或者 val 的值为 False ,则表示值为 0 。

示例

示例 1:

输入:grid = [[0,1],[1,0]]
输出:[[0,1],[1,0],[1,1],[1,1],[1,0]]
解释:此示例的解释如下: 请注意,在下面四叉树的图示中,0 表示 false,1 表示 True 。

示例 2:

输入:grid = [[1,1,1,1,0,0,0,0],[1,1,1,1,0,0,0,0],[1,1,1,1,1,1,1,1],[1,1,1,1,1,1,1,1],[1,1,1,1,0,0,0,0],[1,1,1,1,0,0,0,0],[1,1,1,1,0,0,0,0],[1,1,1,1,0,0,0,0]]
输出:[[0,1],[1,1],[0,1],[1,1],[1,0],null,null,null,null,[1,0],[1,0],[1,1],[1,1]]
解释:网格中的所有值都不相同。我们将网格划分为四个子网格。 topLeft,bottomLeft 和 bottomRight均具有相同的值。 topRight 具有不同的值,因此我们将其再分为 4 个子网格,这样每个子网格都具有相同的值。 解释如下图所示:

示例 3:

输入:grid = [[1,1],[1,1]]
输出:[[1,1]]

示例 4:

输入:grid = [[0]]
输出:[[1,0]]

示例 5:

输入:grid = [[1,1,0,0],[1,1,0,0],[0,0,1,1],[0,0,1,1]]
输出:[[0,1],[1,1],[1,0],[1,0],[1,1]]

思路

又是看不懂题目的一天。。。。。

大致题意应该为,将一个大区域划分为若干个小区域(要求每个小区域中的val全部一致),每次都是将一个大区域划分为4份(直到小区域val全部一致,终止)。

使用深度优先遍历,调用函数dfs(r0: int, c0: int, r1: int, c1: int)从左至右分别是该格子的上侧行边界、左侧列边界、下册行边界,右侧列边界,首先判断当前格子中是否所有元素都等于左上角第一个元素, 如果相等直接返回Node(grid[r0][c0] == 1, True), 否则将该格子分别分为上下左右四个位置递归调用,具体边界分别为:
dfs(r0, c0, (r0 + r1) // 2, (c0 + c1) // 2),
dfs(r0, (c0 + c1) // 2, (r0 + r1) // 2, c1),
dfs((r0 + r1) // 2, c0, r1, (c0 + c1) // 2),
dfs((r0 + r1) // 2, (c0 + c1) // 2, r1, c1),

题解

"""
# Definition for a QuadTree node.
class Node:def __init__(self, val, isLeaf, topLeft, topRight, bottomLeft, bottomRight):self.val = valself.isLeaf = isLeafself.topLeft = topLeftself.topRight = topRightself.bottomLeft = bottomLeftself.bottomRight = bottomRight
"""class Solution:def construct(self, grid: List[List[int]]) -> 'Node':def dfs(r0: int, c0: int, r1: int, c1: int) -> 'Node':# 直接返回if all(grid[i][j] == grid[r0][c0] for i in range(r0, r1) for j in range(c0, c1)):return Node(grid[r0][c0] == 1, True)# 分上下左右四个边界递归进行return Node(True,False,dfs(r0, c0, (r0 + r1) // 2, (c0 + c1) // 2),dfs(r0, (c0 + c1) // 2, (r0 + r1) // 2, c1),dfs((r0 + r1) // 2, c0, r1, (c0 + c1) // 2),dfs((r0 + r1) // 2, (c0 + c1) // 2, r1, c1),)return dfs(0, 0, len(grid), len(grid))

LeetCode每日一题——427. 建立四叉树相关推荐

  1. LeetCode 427. 建立四叉树

    427. 建立四叉树 题目来源:427. 建立四叉树 2022.04.29 每日一题 LeetCode 题解持续更新中GitHub仓库地址 CSDN博客地址 今天的题目一看,有点吓人,上来就给弄了个四 ...

  2. Java实现 LeetCode 427 建立四叉树

    427. 建立四叉树 我们想要使用一棵四叉树来储存一个 N x N 的布尔值网络.网络中每一格的值只会是真或假.树的根结点代表整个网络.对于每个结点, 它将被分等成四个孩子结点直到这个区域内的值都是相 ...

  3. LeetCode——427. 建立四叉树

    427. 建立四叉树 题目描述 答案 方法一:递归 思路与算法 代码 方法二:递归 + 二维前缀和优化 思路与算法 代码 复杂度分析 题目描述 给你一个 n * n 矩阵 grid ,矩阵由若干 0 ...

  4. LeetCode题解:427. 建立四叉树

    文章目录 题目 427. 建立四叉树 1.题目描述 2.原题链接 解题报告 1.解题思路 2.解题方法 3.时间复杂度分析 4.代码详解 总结 前缀和实现 题目 427. 建立四叉树 1.题目描述   ...

  5. LeetCode每日一题打卡组队监督!刷题群!

    近 2000 人已经加入共同刷题啦! 群友每天都会在群里给大家讲解算法题 每周日「负雪明烛」组织直播讲题 我相信来看我博客的大部分人都是通过LeetCode刷题过来的.最近发现LeetCode中文网站 ...

  6. leetcode每日刷题计划-简单篇day8

    leetcode每日刷题计划-简单篇day8 今天是纠结要不要新买手机的一天QAQ想了想还是算了吧,等自己赚钱买,加油 Num 70 爬楼梯 Climbing Stairs class Solutio ...

  7. Leetcode每日一题:171.excel-sheet-column-number(Excel表列序号)

    思路:就是168题的反命题,进制的方式完美解决: Leetcode每日一题:168.excel-sheet-column-title(Excel表名称) class Solution {public: ...

  8. 【LeetCode每日一题】1723. 完成所有工作的最短时间

    [LeetCode每日一题]1723. 完成所有工作的最短时间 [1] 1723. 完成所有工作的最短时间 [2] 473. 火柴拼正方形 [1] 1723. 完成所有工作的最短时间 题目: 给你一个 ...

  9. leetcode每日一题--雀巢原理;抽屉算法;Quorum机制;分布式应用

    leetcode每日一题 539. 最小时间差 示例 1: 输入:timePoints = ["23:59","00:00"] 输出:1 示例 2: 输入:ti ...

最新文章

  1. 盘点 | 2020年「21篇」医学影像算法最佳综述
  2. python isinstance type区别
  3. IT职场人生系列之十四:经验积累
  4. 【数据结构与算法】之有序数组中的单一元素的算法
  5. Java实现根据地理位置获取经纬度
  6. 前端学习(2630):git安装包下载
  7. 流量复制_快速体验之《gor+diffy实现线上流量复制到测试环境》
  8. 上万条数据撕开微博热搜的真相!
  9. 看了就知道为什么别人C语言学习效率那么高了
  10. linux 中的gzip命令
  11. 编程谜题:提升你解决问题的训练场
  12. 专用计算机 一级专用计算机芯片,计算机一级考试 2015年模拟题(一)
  13. 渲染怎么加hdri_关于渲染参数设置,伽马2.2你想要知道的一切!
  14. POJ3070 Fibonacci【矩阵快速幂】
  15. 慕课python第六周测验答案_大学慕课2020Python编程基础章节测验答案
  16. Json对象与Json字符串互转(四种转换方式)
  17. 使用现有在线翻译服务进行代码翻译的体验
  18. springboot中使用thymeleaf片段引入出现500错误(易错)
  19. 有了抖音账号,应该这样做
  20. 闭关之现代 C++ 笔记汇总(二):特性演化

热门文章

  1. 3D打印、区块链认证,实景三维技术正在创造无限可能
  2. 代码实现多啦A梦效果图
  3. CSS3,哆啦A梦动画特效
  4. 自定义C语言CVector
  5. 成为一个合格的Linux用户(四)
  6. ffmpeg RSTP基于Html5视频监控直播 工业设备健康度检测应用
  7. 锂离子电池的主要构成部分
  8. 知乎2018暴露出来哪些漏洞?
  9. 放大器中放大倍数(增益)单位为倍和单位为dB的相互转换
  10. bootstrap打开模态滚动条modal窗口引起页面抖动解决办法