当前位置: 首页 > news >正文

面试150 建立四叉树

在这里插入图片描述

思路

采用递归分治的思路构建四叉树。首先判断当前区域内的值是否全部相同,若是,则构建一个叶子节点;若否,则将区域划分为四个子区域(左上、右上、左下、右下),对每个子区域递归构建对应的子节点,并将其作为当前非叶子节点的四个子树。通过不断划分和合并,实现将二维网格压缩为一棵结构紧凑的四叉树。

"""
# 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':n=len(grid)def isSame(x,y,size):val=grid[x][y]for i in range(x,x+size):for j in range(y,y+size):if grid[i][j]!=val:return False,valreturn True,valdef build(x,y,size):same,val=isSame(x,y,size)if same:return Node(val==1,True)else:half=size//2return Node(val=True,isLeaf=False,topLeft=build(x,y,half),topRight=build(x,y+half,half),bottomLeft=build(x+half,y,half),bottomRight=build(x+half,y+half,half))return build(0,0,n)
http://www.dtcms.com/a/293882.html

相关文章:

  • 电脑32位系统能改64位系统吗
  • Linux下的lcd屏幕显示操作
  • 【前端】【Vue DevTools】Vue DevTools 进阶:用 Trae / Cursor 替换 VSCode 打开文件(跳转行列无误)
  • 直播一体机技术方案解析:基于RK3588S的硬件架构特性​
  • 7.23 减肥感悟
  • 为什么IMU是无人机稳定控制的的核心?
  • 深入解析Hive SQL转MapReduce的编译原理:从AST抽象语法树到Operator执行树
  • 无人机光伏巡检误检率↓78%!陌讯多模态融合算法实战解析
  • 【趣味解读】淘宝登录的前后端交互机制:Cookie-Session 如何保障你的账户安全?
  • 【网络编程】二、socket编程
  • 趣玩-Ollama-Llm-Chatrbot
  • 前端开发 React 状态优化
  • readelf -d a.out | vim - 和 readelf -d a.out | vim 有什么区别?
  • PyTorch武侠演义 第一卷:初入江湖 第5章:玉如意的秘密
  • gig-gitignore工具实战开发(一):项目愿景与蓝图规划
  • C Primer Plus 第6版 编程练习——第10章(上)
  • 漫画机器学习播客对话图文版
  • TGD第二篇:破局——去除导数计算中的无穷小极限
  • CodeBuddy IDE实战:用AI全栈能力快速搭建课程表网页
  • 【机器学习深度学习】比较 LLaMA-Factory、vLLM 和 LMDeploy 的量化导出:为何 LLaMA-Factory 不是首选?
  • 2025暑期—06神经网络-常见网络3
  • UWA DAY 2025 游戏开发者大会|全议程
  • Java UDP 通信详解:从基础到实战,彻底掌握无连接网络编程
  • Python进阶知识之pandas库(一)基础数据类型
  • 论文略读:REMEDY: RECIPE MERGING DYNAMICS IN LARGE VISION-LANGUAGE MODELS
  • 深入解析预训练语言模型在文本生成中的革命性应用:技术全景与未来挑战
  • 【Elasticsearch】跨集群检索(Cross-Cluster Search)
  • 18.设备虚拟化
  • Java 堆(优先级队列)
  • Linux基本指令:掌握系统操作的钥匙