力扣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

相关文章

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>

POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能

《POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能》ApachePOI是一个流行的Java库,用于处理MicrosoftOffice格式文件,提供丰富API来创建、读取和修改O... 目录前言:Apache POIEasyPoiEasyExcel一、EasyExcel1.1、核心特性

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Pandas中统计汇总可视化函数plot()的使用

《Pandas中统计汇总可视化函数plot()的使用》Pandas提供了许多强大的数据处理和分析功能,其中plot()函数就是其可视化功能的一个重要组成部分,本文主要介绍了Pandas中统计汇总可视化... 目录一、plot()函数简介二、plot()函数的基本用法三、plot()函数的参数详解四、使用pl

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处