Mkdir700's Note

Mkdir700's Note

二分查找

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

1818. 绝对值差和

给定两个正整数数组 nums1 和 nums2,长度均为 n。定义数组 nums1 和 nums2 的绝对差值和为所有 |nums1[i] - nums2[i]|(0 <= i < n)的总和。可以选择 nums1 中的任意一个元素来替换 nums1 中的至多一个元素,以最小化绝对差值和。在替换数组 nums1 中最多一个元素之后,返回最小绝对差值和。通过二分查找,找出最适合用于替换当前元素的元素,使绝对值差和最小。最终绝对差值和减少值为遍历过程中 diff - new_diff 的最大值。
716
0
0
2022-09-03
658. 找到 K 个最接近的元素

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

给定排序好的数组 arr,两个整数 k 和 x,找到最靠近 x 的 k 个数,返回按升序排好的结果。题解中使用滑动窗口的方法,逆向思考去掉 len(arr) - k 个数后剩下的窗口即为答案。通过比较左右两端与 x 的距离,逐步缩小范围找到最接近的 k 个元素。算法时间复杂度较低,并且满足题目要求。

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

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