Mkdir700's Note

Mkdir700's Note

算法题

1143. 最长公共子序列
1508. 子数组和排序后的区间和
1818. 绝对值差和

1818. 绝对值差和

给定两个正整数数组 `nums1` 和 `nums2`,数组长度均为 `n`。定义绝对差值和为所有元素差值的总和。替换 `nums1` 中的至多一个元素,以最小化绝对差值和,返回最小绝对差值和。解决方案通过二分查找找出最合适的替换元素,使绝对差值和最小。遍历 `nums1` 中的所有元素,通过排序后的数组二分查找最接近 `nums2[i]` 的元素,选择使绝对差值最小的元素进行替换,最终减少绝对值差和的最大值。返回答案取余。
668
0
0
2022-09-03
611. 有效三角形的个数

611. 有效三角形的个数

描述给定一个包含非负整数的数组 nums ,返回其中可以组成三角形三条边的三元组个数。示例 1:输入: nums = [2,2,3,4]输出: 3**解释:**有效的组合是:2,3,4 (使用第一个 2)2,3,4 (使用第二个 2)2,2,3示例 2:输入: nums = [4,2,3,4]输出:
537
0
0
2022-08-28
658. 找到 K 个最接近的元素

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

给定一个排序好的数组 arr,两个整数 k 和 x,从数组中找到最靠近 x(两数之差最小)的 k 个数。整数 a 比整数 b 更接近 x 需要满足:|a - x| < |b - x| 或者 |a - x| == |b - x| 且 a < b。通过滑动窗口算法,从数组中找出 k 个最接近 x 的数。算法逆向思考,去掉 len(arr) - k 个数,剩下的窗口即为答案。根据滑动窗口算法实现函数 findClosestElements,返回最终的结果数组。

【LC】剑指 Offer 14- I. 剪绳子

给你一根长度为 n 的绳子,请把绳子剪成整数长度的 m 段(m、n都是整数,n>1并且m>1),每段绳子的长度记为 k[0],k[1]...k[m-1] 。请问 k[0]*k[1]*...*k[m-1] 可能的最大乘积是多少?例如,当绳子的长度是8时,我们把它剪成长度分别为2、3、3的三段,此时得到的最大乘积是18

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

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

【LC】542. 01 矩阵

给定一个由 0 和 1 组成的矩阵 mat ,请输出一个大小相同的矩阵,其中每一个格子是 mat 中对应位置元素到最近的 0 的距离。两个相邻元素间的距离为 1 。 示例 1:输入:mat = [[0,0,0],[0,1,0],[0,0,0]]输出:[[0,0,0],[0,1,0],[0,0,0]]