Python高级数据结构——线段树(Segment Tree)

Python中的线段树(Segment Tree):高级数据结构解析

线段树是一种专用于处理区间查询的数据结构,在解决范围内的查询和更新操作时具有高效性能。在本文中,我们将深入讲解Python中的线段树,包括线段树的基本概念、构建、查询和更新操作,并使用代码示例演示线段树的使用。

基本概念

1. 线段树的表示

线段树通过递归地将数组分成不同的区间来构建。每个节点代表数组的一个区间,包括该区间的起始和结束索引、区间的和或最大值等信息。

class SegmentTreeNode:def __init__(self, start, end):self.start = startself.end = endself.sum = 0  # 区间和self.left = Noneself.right = Noneclass SegmentTree:def __init__(self, nums):self.root = self._build_tree(nums, 0, len(nums) - 1)def _build_tree(self, nums, start, end):if start > end:return Noneif start == end:return SegmentTreeNode(start, end)mid = (start + end) // 2root = SegmentTreeNode(start, end)root.left = self._build_tree(nums, start, mid)root.right = self._build_tree(nums, mid + 1, end)return root# 查询区间和def query(self, root, start, end):if not root or start > root.end or end < root.start:return 0if start <= root.start and end >= root.end:return root.summid = (root.start + root.end) // 2return self.query(root.left, start, min(mid, end)) + \self.query(root.right, max(mid + 1, start), end)# 更新节点值def update(self, root, index, val):if not root:returnif root.start == root.end == index:root.sum = valreturnmid = (root.start + root.end) // 2if index <= mid:self.update(root.left, index, val)else:self.update(root.right, index, val)root.sum = root.left.sum + root.right.sum# 示例
nums = [1, 3, 5, 7, 9, 11]
seg_tree = SegmentTree(nums)
print(seg_tree.query(seg_tree.root, 1, 4))  # 输出: 25
seg_tree.update(seg_tree.root, 2, 6)
print(seg_tree.query(seg_tree.root, 1, 4))  # 输出: 29

应用场景

线段树广泛应用于处理区间查询的场景,例如:

  1. 区间和查询: 查询数组中某个区间的和。
  2. 区间最值查询: 查询数组中某个区间的最大值或最小值。
  3. 离线算法: 在大规模数据中进行区间操作的离线算法。
代码示例:解决区间和查询问题
# 创建线段树
nums = [1, 3, 5, 7, 9, 11]
seg_tree = SegmentTree(nums)# 查询区间和
result = seg_tree.query(seg_tree.root, 1, 4)
print(f"区间和: {result}")  # 输出: 区间和: 25# 更新节点值
seg_tree.update(seg_tree.root, 2, 6)# 再次查询区间和
result = seg_tree.query(seg_tree.root, 1, 4)
print(f"更新后的区间和: {result}")  # 输出: 更新后的区间和: 29

总结

线段树是一种高效处理区间查询的数据结构,通过构建树形结构,能够在对数时间内完成查询和更新操作。在Python中,我们可以利用类似上述示例的代码实现线段树,并根据实际问题定制查询和更新的操作。理解线段树的基本概念、构建方式和应用场景,将有助于更好地应用线段树解决实际问题,提高算法的效率。在实际应用中,线段树常被用于解决区间操作问题,如区间和查询、区间最值查询等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/201273.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2023.2版idea安装教程,现在jdk8已经过去式了,不同idea支持的jdk不同。升级jdk后idea也要随之升级

下载idea2023.2版本&#xff0c;下载之前需要删除之前的版本&#xff0c;一定要删除干净&#xff0c;删除程序要勾选那两个delete 下载路径&#xff1a;其他版本 - IntelliJ IDEA (jetbrains.com.cn) 选择2023.2版本 下载后进入安装程序&#xff0c;选择安装目录&#xff0c;然…

java实验:数据库应用(idea+mysql+php)设计用户注册和登录

设计用户注册和登录界面&#xff0c;实现用户注册和登录操作。 设计用户注册/登录界面;使用工具在MySQL中创建user表&#xff0c;包括学号、姓名、密码、专业、班级&#xff1b;实现注册操作&#xff1a;在user表中插入一条新纪录&#xff0c;但学号不能重复&#xff1b;实现登…

uniapp使用vue-i18n国际化多国语言

前言&#xff1a;uniapp是自带有i18n这个插件的&#xff0c;如果没有npm安装即可 此插件需要自己去给每一个需要国际化的字符去手动配置key&#xff0c;所以如果是已经完成的项目可能工作量就稍微有点大了 第一步&#xff1a; 语言命名是有规范的不能乱取名&#xff0c;具体可…

电容电感特性的理解

04730电子技术基础 语雀 在前面&#xff0c;我们提到过电容元件具有隔直通交&#xff0c;通高阻低的特性&#xff0c;电感元件具有隔交通直&#xff0c;通低阻高的特性。那么如何理解这两句话呢&#xff1f;下面我们一一剖析 电容元件的隔直通交&#xff0c;通高阻低的特性 …

MySQL五 | 事务

目录 事务操作 查看/设置事务提交方式 方式一 提交事务 回滚事务 方式二 开启事务 提交事务 回滚事务 事务四大特性(ACID) 事务的隔离级别 查看事务的隔离级别 设置事务隔离级别 事务操作 是一组操作的集合&#xff0c;是一个不可分割的工作单位&#xff0c;会把所…

【C】递归函数

一、什么是递归 递归其实是⼀种解决问题的⽅法&#xff0c;在C语⾔中&#xff0c;递归就是函数⾃⼰调⽤⾃⼰。 我们先了解一个知识&#xff1a; 每一次函数调用&#xff0c;都会向内存栈区上申请一块空间。 这块空间主要用来存放函数中的局部变量&#xff0c;和函数调用过程中…

点滴生活记录1

2023/10/10 今天骑小电驴上班&#xff0c;带着小鸭子一起。路上的时候&#xff0c;我给小鸭子说&#xff0c;你要帮我看着点路&#xff0c;有危险的时候提醒我&#xff0c;也就刚说完没几分钟&#xff0c;一个没注意&#xff0c;直接撞到一个拦路铁墩子上&#xff0c;车子连人歪…

《亲密关系》阅读笔记

前言 仅记录学习笔记&#xff0c;如有错误欢迎指正。 感受&#xff1a; 看完才发现&#xff0c;引用竟然占了大概10分之一的厚度> < ! 这本书更多是实验&#xff0c;数据来支撑观点的&#xff0c;还鄙夷了《男人来自火星&#xff0c;女人来自金星》这本书&#xff0c;说…

12、组合模式(Composite Pattern,不常用)

组合模式&#xff08;Composite Pattern&#xff09;&#xff0c;有时又叫作部分-整体模式&#xff0c;它是一种将对象组合成树状的层次结构的模式&#xff0c;用来表示“部分-整体”的关系&#xff0c;使用户对单个对象和组合对象具有一致的访问性。 它在我们树型结构的问题中…

python实现模拟用户点击行为测试

目录 一、需求背景 二、爬虫需求实战测试 1、目标需求: 可实现遍历访问多个html网页地址

【Java——反射机制详解】

JAVA反射机制是在运行状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的所有属性和方法&#xff1b;对于任意一个对象&#xff0c;都能够调用它的任意一个方法和属性&#xff1b;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。Java反…

2023年度端侧transformer类分类力作SwiftFormer模型解读

写在前面&#xff1a;本篇直接结合代码来理解网络的笔记 paper: Swiftformer-paper code: https://github.com/Amshaker/SwiftFormer 文章目录 网络结构精析零、整体一、patch embed二、stage 网络结构精析 零、整体 可以看到结构中&#xff0c;整体就是&#xff1a; stem -&…

【C#】MathNet矩阵计算

文章目录 安装索引和计算逐点计算静态方法 MathNet系列&#xff1a;矩阵生成 安装 MathNet.Numerics中提供了线性代数、微积分、特殊函数、概率论、随机函数、插值、最优化等一系列功能&#xff0c;是.net技术中首选的数值计算包。 其中&#xff0c;线性代数包LinearAlgebra…

深度学习——第3章 Python程序设计语言(3.4 Python自定义函数)

3.4 Python自定义函数 目录 1. 函数基础知识 2. 函数的定义&#xff08;声明&#xff09;和调用 3. 函数参数传递 4. 函数的返回值 5. lambda函数 随着学习的日渐深入&#xff0c;编写的代码将会越来越复杂&#xff0c;所以我们需要找一种方法对这些复杂的代码进行分解、重…

iphone/安卓手机如何使用burp抓包

iphone 1. 电脑 ipconfig /all 获取电脑网卡ip&#xff1a; 192.168.31.10 2. 电脑burp上面打开设置&#xff0c;proxy&#xff0c;增加一条 192.168.31.10:8080 3. 4. 手机进入设置 -> Wi-Fi -> 找到HTTP代理选项&#xff0c;选择手动&#xff0c;192.168.31.10:8080 …

Windows/Linux 设置固定IP

Windows/Linux 设置固定IP 在开发过程中 会经常遇到要与前端进行本地的联调 过了两天 发现 不知道为什么 ip发生了改变 所以 就写一个 windows 与linux 固定ip的博客 记录一下 Windows 话不多说 看下图 上方输入 ipconfig/all 就会出来一堆信息 下面是一些有用的信息 默认…

超使用的十个JavaScript技巧

前端面试题库 &#xff08;面试必备&#xff09; 推荐&#xff1a;★★★★★ 地址&#xff1a;前端面试题库 JavaScript 作为最流行的语言之一&#xff0c;其语法灵活且每年都在不断吸纳新特性&#xff0c;即使是一个从业多年的老手&#xff0c; 偶尔也会有一些被…

04武忠祥0基础

收敛数列的性质 唯一性&#xff1a; 反证法&#xff1a; 发散不一定无界 举个例子&#xff0c;考虑以下数列&#xff1a; a_n (-1)^n 这个数列的每一项交替地取正负值。当 n 是偶数时&#xff0c;a_n 1&#xff0c;当 n 是奇数时&#xff0c;a_n -1。这个数列明显是发…

编程实战:类C语法的编译型脚本解释器(八)编译概览

系列入口&#xff1a;编程实战&#xff1a;类C语法的编译型脚本解释器&#xff08;系列&#xff09;-CSDN博客 前面已经介绍了Token、变量、变量表、表达式和语句&#xff0c;现在进入深水区&#xff0c;介绍编译过程&#xff0c;相当于解释型脚本的解释过程。 编译的好处是提前…

GO学习之 单例模式 sync.Once

GO系列 1、GO学习之Hello World 2、GO学习之入门语法 3、GO学习之切片操作 4、GO学习之 Map 操作 5、GO学习之 结构体 操作 6、GO学习之 通道(Channel) 7、GO学习之 多线程(goroutine) 8、GO学习之 函数(Function) 9、GO学习之 接口(Interface) 10、GO学习之 网络通信(Net/Htt…