力扣1109. 航班预订统计 差分入门模板题 附线段树解法

2023-10-31 06:04

本文主要是介绍力扣1109. 航班预订统计 差分入门模板题 附线段树解法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原题

本题属于「区间求和」问题中的入门难度。

差分解法:

class Solution {/*本题只涉及「区间修改 + 单点查询」,因此是一道「差分」的模板题。「差分」可以看做是求「前缀和」的逆向过程。对于一个「将区间[L,R]整体增加一个值 V」操作,我们可以对差分数组 C 的影响看成两部分:对 C[L]+=V:由于差分是前缀和的逆向过程,这个操作对于将来的查询而言,带来的影响是对于所有的下标大于等于L的位置都增加了值V;对 C[R+1]-=V:由于我们期望只对[L,R]产生影响,因此需要对下标大于R的位置进行减值操作,从而抵消“影响”。对于最后的构造答案,可看做是对每个下标做“单点查询”操作,只需要对差分数组求前缀和即可:
*/public int[] corpFlightBookings(int[][] bookings, int n) {int pre[]=new int[n+1],ans[]=new int[n]; //pre[]必须声明成n+1 因为C[R+1]-=V时R+1有可能越界了for (int[] booking : bookings) {int firsti=booking[0],lasti=booking[1],seatsi=booking[2];pre[firsti-1]+=seatsi;pre[lasti]-=seatsi;}ans[0]=pre[0];for (int i = 1; i < n; i++) {ans[i]=ans[i-1]+pre[i];}return ans;}
}

线段树可以无脑解决所有的「区间求和」问题,但是很多时候没必要,代码量太大,表现也不是最好的:

class Solution {public int[] corpFlightBookings(int[][] bookings, int n) {for (int[] booking : bookings) {int l=booking[0]-1,r=booking[1]-1,seatsi=booking[2];update(root,0,n,l,r,seatsi);}int ans[] = new int[n];for (int i = 0; i < n; i++) {ans[i]=query(root,0,n,i,i);}return ans;}class Node {Node left, right;int val, add;}private int N = (int) 2e4;//线段树范围大小private Node root = new Node();// 在区间 [start, end] 中更新区间 [l, r] 的值,将区间 [l, r] ➕ val// 如果结点表示为「区间最值」的情况时在更新结点时不需要✖️叶子节点的数量// 下面的pushDown函数里也是 也要根据题目判断是否需要✖️叶子节点的数量// 如果是「点更新」 也不需要✖️叶子节点的数量  因为此时区间是一个点所以一定会更新到叶子节点//start, end一般是用0和N 对应root的范围!public void update(Node node, int start, int end, int l, int r, int val) {if (l <= start && end <= r) {node.val += (end - start + 1) * val;//✖️叶子节点的数量node.add += val;//这里俩个+=如果在点赋值时可以改成= 点累加不行return ;}int mid = (start + end) >> 1;pushDown(node, mid - start + 1, end - mid);if (l <= mid) update(node.left, start, mid, l, r, val);if (r > mid) update(node.right, mid + 1, end, l, r, val);pushUp(node);}// 在区间 [start, end] 中查询区间 [l, r] 的结果, [l ,r] 保持不变public int query(Node node, int start, int end, int l, int r) {if (l <= start && end <= r) return node.val;int mid = (start + end) >> 1, ans = 0;pushDown(node, mid - start + 1, end - mid);if (l <= mid) ans += query(node.left, start, mid, l, r);if (r > mid) ans += query(node.right, mid + 1, end, l, r);return ans;}// 向上更新private void pushUp(Node node) {node.val = node.left.val + node.right.val;}// 推懒惰标记的函数// 如果是「覆盖」的更新操作 则在下推懒惰标记的时候『不需要累加』private void pushDown(Node node, int leftNum, int rightNum) {if (node.left == null) node.left = new Node();if (node.right == null) node.right = new Node();if (node.add == 0) return ;// 当前节点加上标记值✖️该子树所有叶子节点的数量 同上面update函数同步修改node.left.val += node.add * leftNum;node.right.val += node.add * rightNum;//这里俩个+=如果在点赋值时可以改成= 点累加不行// 对区间进行「加减」的更新操作时,下推懒惰标记时需要累加起来,不能直接覆盖node.left.add += node.add;node.right.add += node.add;node.add = 0;}
}

这篇关于力扣1109. 航班预订统计 差分入门模板题 附线段树解法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/313330

相关文章

Java利用Spire.Doc for Java实现在模板的基础上创建Word文档

《Java利用Spire.DocforJava实现在模板的基础上创建Word文档》在日常开发中,我们经常需要根据特定数据动态生成Word文档,本文将深入探讨如何利用强大的Java库Spire.Do... 目录1. Spire.Doc for Java 库介绍与安装特点与优势Maven 依赖配置2. 通过替换

SpringCloud Stream 快速入门实例教程

《SpringCloudStream快速入门实例教程》本文介绍了SpringCloudStream(SCS)组件在分布式系统中的作用,以及如何集成到SpringBoot项目中,通过SCS,可... 目录1.SCS 组件的出现的背景和作用2.SCS 集成srping Boot项目3.Yml 配置4.Sprin

SpringMVC配置、映射与参数处理​入门案例详解

《SpringMVC配置、映射与参数处理​入门案例详解》文章介绍了SpringMVC框架的基本概念和使用方法,包括如何配置和编写Controller、设置请求映射规则、使用RestFul风格、获取请求... 目录1.SpringMVC概述2.入门案例①导入相关依赖②配置web.XML③配置SpringMVC

Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)

《Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)》在职场中,Word文档是公认的好伙伴,但你有没有被它折磨过?批量生成合同、制作报告以及发放证书/通知等等,这些重复、低效... 目录重复性文档制作,手动填充模板,效率低下还易错1.python-docx入门:Word文档的“瑞士

MySQL索引踩坑合集从入门到精通

《MySQL索引踩坑合集从入门到精通》本文详细介绍了MySQL索引的使用,包括索引的类型、创建、使用、优化技巧及最佳实践,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录mysql索引完整教程:从入门到入土(附实战踩坑指南)一、索引是什么?为什么需要它?1.1 什么

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

Python进行word模板内容替换的实现示例

《Python进行word模板内容替换的实现示例》本文介绍了使用Python自动化处理Word模板文档的常用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录技术背景与需求场景核心工具库介绍1.获取你的word模板内容2.正常文本内容的替换3.表格内容的

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚