Leetcode 370、1109、1094差分数组考点

1.370 区间加法

问题:假设你有一个长度为n的数组,初始情况下所有的数字均为0,你将会被给出
k个更新的操作,其中,每个操作会被表示为一个三元组:[startIndex, endIndex, inc],你需要将子数组A[startIndex...endIndex]增加inc,请返回k次操作后的数组。输入:length=5,updates=[[1,3,2],[2,4,3],[0,2,-2]],输出:[-2,0,3,5,3]。

解答:若每次for循环给区间[startIndex, endIndex]加上inc,那么会频繁对原始数组进行更新,效率非常低,时间复杂度为O(N)。

优化为:一个差分数组,存储前后两个元素之间的差,令diff[startIndex] += inc;diff[endIndex + 1] -=inc,由此实现给出数组的第一个元素值和差分数组,就能求出整个数组,时间复杂度为O(1)。

2.1109 航班预定统计

问题:这里有 n 个航班,它们分别从 1 到 n 进行编号。有一份航班预订表 bookings ,表中第 i 条预订记录 bookings[i] = [firsti, lasti, seatsi] 意味着在从 firsti 到 lasti (包含 firsti 和 lasti )的 每个航班 上预订了 seatsi 个座位。请你返回一个长度为 n 的数组 answer,里面的元素是每个航班预定的座位总数。

解答:标准差分数组题。

3.1094 拼车

问题:车上最初有capacity 个空座位。车只能向一个方向行驶(也就是说,不允许掉头或改变方向)给定整数capacity 和一个数组trips ,  trip[i] = [numPassengersi, fromi, toi] 表示第 i 次旅行有numPassengersi 乘客,接他们和放他们的位置分别是fromi 和toi 。这些位置是从汽车的初始位置向东的公里数。当且仅当你可以在所有给定的行程中接送所有乘客时,返回true,否则请返回false

解答:旅客上下车相当于区间的加减,只要最后的数组元素都小于capacity,就表示不会超载。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值