Mkdir700's Note

Mkdir700's Note

二分查找

1508. 子数组和排序后的区间和
1818. 绝对值差和

1818. 绝对值差和

给定两个正整数数组 nums1 和 nums2,数组的长度都是 n。数组 nums1 和 nums2 的绝对差值和定义为所有 |nums1[i] - nums2[i]| 的总和。可以替换 nums1 中的最多一个元素,以最小化绝对差值和。需要返回最小绝对差值和,对 10^9 + 7 取余后返回。通过二分查找,选择最合适的元素来替换,使得整体绝对值差和最小。列举了示例和提示,最终给出了二分查找的具体实现代码。
765
0
0
2022-09-03
658. 找到 K 个最接近的元素

658. 找到 K 个最接近的元素

给定一个排序好的数组 arr,两个整数 k 和 x,从数组中找到最靠近 x 的 k 个数。整数 a 比整数 b 更接近 x 需要满足:|a - x| < |b - x| 或者 |a - x| == |b - x| 且 a < b。利用滑动窗口,逆向思考去掉 len(arr) - k 个数,剩下的窗口即为答案。示例 1 输入:arr = [1,2,3,4,5], k = 4, x = 3,输出:[1,2,3,4]。示例 2 输入:arr = [1,2,3,4,5], k = 4, x = -1,输出:[1,2,3,4]。算法实现如下。

【LC】875. 爱吃香蕉的珂珂

珂珂喜欢吃香蕉。这里有 N 堆香蕉,第 i 堆中有 piles[i] 根香蕉。警卫已经离开了,将在 H 小时后回来。珂珂可以决定她吃香蕉的速度 K (单位:根/小时)。每个小时,她将会选择一堆香蕉,从中吃掉 K 根。如果这堆香蕉少于 K 根,她将吃掉这堆的所有香蕉,然后这一小时内不会再吃更多的香蕉。
901
0
0
2022-02-26