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

33-47 树

33. 二叉树的中序遍历class Solution(object): def inorderTraversal(self, root): res [] self._inorder(root, res) return res def _inorder(self, node, res): if node: self._inorder(node.left, res) res.append(node.val) self._inorder(node.right, res)34. 二叉树的最大深度class Solution(object): def _inorder(self,root): if root: aself._inorder(root.left) bself._inorder(root.right) return max(a,b)1 else: return 0 def maxDepth(self, root): return self._inorder(root)35. 翻转二叉树class Solution(object): def invertTree(self, root): if root: temroot.right root.rightroot.left root.lefttem self.invertTree(root.left) self.invertTree(root.right) return root36. 对称二叉树class Solution(object): def judge(self,left,right): if left and right: if left.val!right.val: return False return self.judge(left.right,right.left) and self.judge(left.left,right.right) else: if left or right: return False return True def isSymmetric(self, root): return self.judge(root.left,root.right)37. 二叉树的直径class Solution(object): def inorder(self,root): if root: aself.inorder(root.left) bself.inorder(root.right) self.max_diammax(self.max_diam,ab) return max(a,b)1 else: return 0 def diameterOfBinaryTree(self, root): self.max_diam 0 self.inorder(root) return self.max_diam38. 二叉树的层序遍历from collections import deque class Solution(object): def levelOrder(self, root): if not root: return [] dqdeque() dq.append(root) ansroot res[] l[] while dq : curdq.popleft() l.append(cur.val) if cur.left: dq.append(cur.left) if cur.right: dq.append(cur.right) if curans: res.append(l) l[] if dq: ansdq[-1] return resclass Solution(object): def inorder(self,root,w): if root: if len(self.res)w: self.res.append([root.val]) else: self.res[w].append(root.val) self.inorder(root.left,w1) self.inorder(root.right,w1) def levelOrder(self, root): self.res[] self.inorder(root,0) return self.res39 将有序数组转换为二叉搜索树class Solution(object): def create_Tree(self,nums,left,right): if leftright: return None elif leftright: return TreeNode(nums[left]) else: midleft(right-left)//2 rootTreeNode(nums[mid]) root.leftself.create_Tree(nums,left,mid-1) root.rightself.create_Tree(nums,mid1,right) return root def sortedArrayToBST(self, nums): if len(nums)0: return None return self.create_Tree(nums,0,len(nums)-1)40. 验证二叉搜索树class Solution(object): def inorder(self,root): if root: aself.inorder(root.left) if root.valself.ans: return False self.ansroot.val bself.inorder(root.right) return a and b else: return True def isValidBST(self, root): self.ans-float(inf) return self.inorder(root)class Solution(object): def isValidBST(self, root): def judge(node,low-float(inf),highfloat(inf)): if not node: return True curnode.val if curlow or curhigh: return False return judge(node.left,low,cur) and judge(node.right,cur,high) return judge(root)41. 二叉搜索树中第 K 小的元素class Solution(object): def kthSmallest(self, root, k): self.kk self.resNone def inorder(node): if node: inorder(node.left) if self.k1: self.resnode.val self.k-1 inorder(node.right) inorder(root) return self.res42. 二叉树的右视图from collections import deque class Solution(object): def rightSideView(self, root): dqdeque() ansroot if not root: return [] dq.append(root) res[] while dq: curdq.popleft() if cur.left: dq.append(cur.left) if cur.right: dq.append(cur.right) if anscur : res.append(cur.val) if dq: ansdq[-1] return res43. 二叉树展开为链表class Solution(object): def flatten(self, root): if root: aself.flatten(root.left) bself.flatten(root.right) if not a and not b: return root root.leftNone root.rightNone if a: root.righta if b: curroot while cur.right: curcur.right cur.rightb return root return None44. 从前序与中序遍历序列构造二叉树class Solution(object): def buildTree(self, preorder, inorder): if len(preorder)1: valpreorder[0] for i in range(len(preorder)): if inorder[i]val: aself.buildTree(preorder[1:1i],inorder[0:i]) bself.buildTree(preorder[1i:],inorder[i1:]) break rootTreeNode(val,a,b) return root return None45. 路径总和 IIIclass Solution(object): def pathSum(self, root, targetSum): if root: def fun(root,targetSum): if root: res1 if root.valtargetSum else 0 resfun(root.left,targetSum-root.val) resfun(root.right,targetSum-root.val) return res return 0 return fun(root,targetSum)self.pathSum(root.left,targetSum)self.pathSum(root.right,targetSum) return 0class Solution(object): def pathSum(self, root, targetSum): self.res0 mp{} mp[0]1 def dfs(node,cur_sum): if node: cur_sumnode.val self.resmp.get(cur_sum-targetSum,0) mp[cur_sum]mp.get(cur_sum,0)1 dfs(node.left,cur_sum) dfs(node.right,cur_sum) mp[cur_sum]-1 else: return dfs(root,0) return self.res46. 二叉树的最近公共祖先class Solution(object): def lowestCommonAncestor(self, root, p, q): if not root or rootp or rootq: return root leftself.lowestCommonAncestor(root.left,p,q) rightself.lowestCommonAncestor(root.right,p,q) if left and right: return root return left if left else right47. 二叉树中的最大路径和class Solution(object): def maxPathSum(self, root): self.max-float(inf) def fun(root): if root: amax(fun(root.left),0) bmax(fun(root.right),0) if root.valabself.max: self.maxroot.valab return max(a,b)root.val return 0 fun(root) return self.max

相关文章:

33-47 树

33. 二叉树的中序遍历 class Solution(object):def inorderTraversal(self, root):res []self._inorder(root, res)return resdef _inorder(self, node, res):if node:self._inorder(node.left, res)res.append(node.val)self._inorder(node.right, res) 34. 二叉树的最大深…...

AI技能库设计:构建大语言模型的可执行能力框架

1. 项目概述:一个AI技能库的诞生与价值最近在GitHub上看到一个挺有意思的项目,叫haliphax-ai/skills。光看名字,你可能会觉得这又是一个关于“技能”的泛泛而谈的仓库。但点进去之后,我发现它的定位非常精准:这是一个专…...

深入S32K144 Lin驱动层:从LPUART中断到回调,拆解LIN_DRV_Init背后的通信时序

深入S32K144 Lin驱动层:从LPUART中断到回调的通信时序解析 在嵌入式开发领域,LIN总线因其低成本、高可靠性的特点,成为车身电子系统中不可或缺的通信协议。而NXP的S32K144微控制器凭借其强大的LPUART外设和灵活的驱动架构,为LIN通…...

Claude Desktop Pro Client:打造本地化AI工作台的架构设计与实践

1. 项目概述与核心价值最近在折腾AI助手本地化部署的时候,发现了一个挺有意思的项目,叫“Claude Desktop Pro Client”。光看名字,你可能会觉得这又是一个给Claude官方桌面端套壳的第三方客户端,但实际深入把玩之后,我…...

MCP协议与Personas角色:为AI助手打造专属工具箱的实践指南

1. 项目概述:当AI助手拥有“专属工具箱”如果你和我一样,每天都在和各类AI助手打交道,从ChatGPT到Claude,再到国内外的各种大模型应用,你可能会发现一个共同的痛点:这些助手虽然知识渊博,但“动…...

Churrera CLI:命令行模板引擎,提升开发运维自动化效率

1. 项目概述:一个为开发者“挤奶油”的命令行工具如果你经常在终端里和 Git、Docker、Kubernetes 或者各种云服务 API 打交道,那你一定对那种重复、繁琐的命令行操作深恶痛绝。每次都要回忆、复制粘贴那一长串参数,或者在不同的项目目录间跳转…...

基于MediaPipe与OpenCV的手腕姿态监测系统WristAssist开发实践

1. 项目概述:手腕的智能守护者最近在折腾一个挺有意思的开源项目,叫WristAssist。这名字听起来就挺有范儿,直译过来是“手腕助手”。简单来说,它是一个利用计算机视觉技术,通过普通摄像头实时监测用户手腕姿态&#xf…...

Qubes OS自动化管理工具qubes-claw:声明式配置与安全隔离实践

1. 项目概述与核心价值最近在折腾一个挺有意思的项目,叫“qubes-claw”。这名字听起来有点神秘,对吧?我第一次看到的时候,也琢磨了半天。简单来说,这是一个专门为Qubes OS设计的自动化工具集。如果你对Qubes OS不熟悉&…...

基于Godot Engine的3D树形结构可视化:从原理到实践

1. 项目概述:从二维到三维的树形结构可视化革命如果你曾经被项目中错综复杂的层级关系搞得头晕眼花,比如一个庞大的组织架构图、一个深不见底的目录树,或者一个复杂的决策流程,那么你肯定尝试过用树形图来梳理它们。传统的树形图&…...

木质防火门基础选购核心要点

在现代建筑消防配套设施体系中,木质防火门凭借外观质感柔和、适配各类室内装修风格、现场安装便捷灵活等优势,被广泛应用于住宅楼宇、商业综合体、办公写字楼、酒店公寓等各类民用与公共建筑场景,是建筑防火分隔、阻断烟火蔓延的核心安防构件…...

uniApp H5项目从打包到上线:一站式解决跨域与Nginx部署

1. uniApp H5项目打包全流程解析 第一次用uniApp打包H5项目时,我对着空白页面和404错误整整折腾了两天。后来才发现,问题出在基础路径配置这个看似简单的环节上。uniApp打包H5和传统Vue项目有些不同,这里我把踩过的坑都总结成可复用的经验。 …...

iOS开发效率提升:Xcode光标规则与编辑技巧全解析

1. 项目概述:一个iOS开发者的“光标规则”宝库 如果你是一名iOS开发者,或者对iOS应用开发感兴趣,那么你一定经历过这样的时刻:在Xcode里写代码,光标在屏幕上闪烁,你希望它能更“聪明”一点——比如&#xf…...

保姆级避坑指南:在Ubuntu 18.04上从零安装Carla 0.9.12/0.9.13(附版本选择与常见报错解决)

从零到精通:Ubuntu 18.04下Carla 0.9.12/0.9.13安装全攻略与深度排错手册 当自动驾驶开发者第一次打开Carla官方文档时,往往会被其丰富的功能所吸引——从多传感器融合到复杂交通场景模拟,这个开源的仿真平台几乎涵盖了自动驾驶研发的所有关…...

基于MCP协议构建个人AI助手:本地化读取Mac消息数据库实践

1. 项目概述:一个让AI助手“读懂”你Mac消息的桥梁如果你和我一样,是个重度依赖Mac原生“信息”应用(也就是iMessage)来沟通的人,同时又希望自己的AI助手(比如Claude、Cursor里的AI)能更深入地了…...

Ubuntu20.04上搞定向日葵远程控制:从下载到解决‘libwebkitgtk-3.0-0’依赖报错的全流程

Ubuntu 20.04 向日葵远程控制安装全攻略:从依赖报错到完美运行 在Linux桌面环境中,远程控制工具的选择往往让新手感到困扰。作为国内用户熟悉的远程协助解决方案,向日葵(SunloginClient)以其简洁的界面和稳定的连接性能…...

XR Interaction Toolkit实战:为HTC Vive Cosmos打造抓取、投掷与UI交互(Unity 2023教程)

XR Interaction Toolkit实战:为HTC Vive Cosmos打造抓取、投掷与UI交互(Unity 2023教程) 在VR开发领域,交互设计始终是决定用户体验的核心要素。当我们谈论HTC Vive Cosmos这样的高端头显时,如何利用Unity 2023和XR In…...

全链路监控与可观测性:Spring AI 应用的日志、追踪与告警体系

系列导读 你现在看到的是《Spring AI 企业级集成与场景实践:从零搭建智能应用》的第 10/10 篇,当前这篇会重点解决:教会读者如何像监控数据库一样监控 AI 调用,快速定位性能瓶颈和异常。 上一篇回顾:第 9 篇《安全防线:Spring AI 应用的输入过滤、输出审核与数据隐私保…...

性能调优与成本控制:Spring AI 的缓存、限流与模型降级策略

系列导读 你现在看到的是《Spring AI 企业级集成与场景实践:从零搭建智能应用》的第 8/10 篇,当前这篇会重点解决:提供一套完整的性能与成本优化工具箱,让 AI 应用在预算内高效运行。 上一篇回顾:第 7 篇《生产级部署:Spring AI 应用的 Docker 容器化与 Kubernetes 编排…...

ARM GICv3中断控制器架构与ICC_CTLR_EL3寄存器解析

1. ARM GICv3中断控制器架构概述在现代处理器架构中,中断控制器是连接外设与CPU核心的关键枢纽。ARM的通用中断控制器(Generic Interrupt Controller, GIC)经过多代演进,GICv3架构在虚拟化支持、多安全域管理和扩展性方面实现了显著提升。作为GICv3的核心…...

基于拓扑结构的多智能体协同系统:从概念到工程实践

1. 项目概述:从单体智能到协同网络的范式演进最近在开源社区里,一个名为agentopology/agentopology的项目引起了我的注意。乍一看这个名字,结合了“Agent”(智能体)和“Topology”(拓扑)&#x…...

开源协作团队实践:从零构建高效技术团队的“团队即代码”方法论

1. 项目概述:一个开源协作团队的诞生与运作最近在GitHub上看到一个挺有意思的项目,叫jefferyjob/openclaw-it-team。光看这个名字,可能有点摸不着头脑,它不像一个具体的软件工具或框架,更像是一个团队或组织的代号。没…...

Carapace:动态生成Shell补全,统一管理命令行工具参数提示

1. 项目概述:一个能“读懂”你心思的Shell补全神器如果你在终端里敲命令时,经常记不住某个复杂工具的参数,或者厌倦了反复按Tab却得不到想要的提示,那么今天聊的这个项目,你一定会感兴趣。它叫Carapace,一个…...

你以为路径不会回头?一道 Self Crossing 让无数人当场破防

你以为路径不会回头?一道 Self Crossing 让无数人当场破防 很多人第一次刷到 Self Crossing(路径交叉) 这道题时,都有一种错觉: “不就是判断线段相交吗?这能有多难?” 结果一写代码: 判断漏了 边界炸了 图形绕晕了 Case 全挂了 最后看题解的时候,人都沉默了。 因为…...

为AI应用构建低成本实时搜索能力:gpt-search开源项目实战指南

1. 项目概述与核心价值最近在折腾一些AI应用开发,发现一个挺有意思的现象:很多开发者想给自己的GPT应用加上联网搜索能力,但往往卡在第一步——如何高效、稳定且低成本地获取实时网络信息。自己从零搭建一个搜索引擎爬虫?光是处理…...

企业级文档自动化平台docmancer:架构解析与工程实践

1. 项目概述:从“文档魔法师”到企业级文档自动化最近在梳理团队内部的知识管理流程时,我一直在寻找一个能够打通文档创建、协作、版本管理和自动化分发的“一体化”解决方案。市面上的工具要么太重,像Confluence那样需要复杂的配置和团队迁移…...

25岁入行编程,30岁实现财务自由:我的4步进阶法

作为一名软件测试从业者,你是否曾在反复的功能验证、bug回归中感到职业瓶颈?是否羡慕身边程序员的高薪与灵活发展路径?我曾和你一样,在测试岗位上摸爬滚打三年,25岁才下定决心转行编程,如今30岁已实现被动收…...

基于Mayan EDMS的文档管理系统部署与优化实践

1. 项目概述:一个面向文档管理的开源解决方案如果你在寻找一个能够替代Confluence、SharePoint,甚至是Google Drive的开源自托管方案,那么joyozhang333-lgtm/mayan-kin这个项目值得你花时间研究。它不是一个全新的轮子,而是基于一…...

程序员的职业规划:到底是走技术路线还是管理路线

程序员职业规划:技术与管理的岔路口在软件测试行业深耕多年,你或许早已习惯在代码的迷宫中寻找漏洞,在数据的海洋里甄别异常。但当职业生涯的列车行至中途,一个现实的问题总会悄然浮现:是继续在技术的山峰上攀登&#…...

TI毫米波雷达的测距极限:带宽、采样率与最大探测距离到底什么关系?

TI毫米波雷达测距极限:从理论公式到工程实践的深度解析 在自动驾驶和工业传感领域,毫米波雷达因其全天候工作能力和精确测距特性成为核心传感器。德州仪器(TI)的AWR和IWR系列雷达芯片凭借高集成度和灵活配置,被广泛应用于无人机避障、智能停车…...

数据库内机器学习:用SQL调用AI模型,简化预测工作流

1. 项目概述:当数据库遇上机器学习最近在开源社区里,一个名为mindsdb/anton的项目引起了我的注意。乍一看,这像是一个普通的数据库项目,但深入了解后,你会发现它试图解决一个困扰了数据工程师和分析师很久的痛点&#…...