Leetcode面试150题
Leetcode 面试150题
NO.88 :合并两个有序数组
给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。
请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。
注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n 。
示例 1:
1 | 输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3 |
示例 2:
1 | 输入:nums1 = [1], m = 1, nums2 = [], n = 0 |
示例 3:
1 | 输入:nums1 = [0], m = 0, nums2 = [1], n = 1 |
提示:
nums1.length == m + nnums2.length == n0 <= m, n <= 2001 <= m + n <= 200-109 <= nums1[i], nums2[j] <= 109
分析:
这个题我一开始的思路是做两个指针p1和p2 从前往后来遍历把元素插入到nums1中,但是我发现对于循环条件的判断不是很明确,所以我采用了这个思路,从后往前遍历,判断循环出去的条件就是是否指针遍历为0
1 | class Solution () { |
NO:27:移除元素
给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素。元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。
假设 nums 中不等于 val 的元素数量为 k,要通过此题,您需要执行以下操作:
- 更改
nums数组,使nums的前k个元素包含不等于val的元素。nums的其余元素和nums的大小并不重要。 - 返回
k。
用户评测:
评测机将使用以下代码测试您的解决方案:
1 | int[] nums = [...]; // 输入数组 |
如果所有的断言都通过,你的解决方案将会 通过。
示例 1:
1 | 输入:nums = [3,2,2,3], val = 3 |
示例 2:
1 | 输入:nums = [0,1,2,2,3,0,4,2], val = 2 |
提示:
0 <= nums.length <= 1000 <= nums[i] <= 500 <= val <= 100
思路:
交换思想,也就是交换val元素与不相等的val元素的值,这样就可以变成删除的感觉
1 | class Solution { |
NO:26. 删除有序数组中的重复项
给你一个 非严格递增排列 的数组 nums ,请你** 原地** 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。
考虑 nums 的唯一元素的数量为 k ,你需要做以下事情确保你的题解可以被通过:
- 更改数组
nums,使nums的前k个元素包含唯一元素,并按照它们最初在nums中出现的顺序排列。nums的其余元素与nums的大小不重要。 - 返回
k
No.120: Triangle(三角形最小路径和)
📖 题目描述
给定一个三角形结构的二维整数列表 triangle:
1 | [ |
从顶端出发,每次只能移动到下一行中相邻的两个数字,求从顶到底路径的 最小总和。
✅ 解题思路:自底向上动态规划(Bottom-Up DP)
🧠 思想
从倒数第二层开始,逐层往上,把每个位置的值更新为:
1 | 当前位置值 + 下面两条路径中较小的值 |
最终,顶端的位置就会变成整个三角形的最小路径和。
💡 状态转移公式
1 | f[i][j] = triangle[i][j] + min(f[i+1][j], f[i+1][j+1]) |
🧪 示例演算
以如下 triangle 为例:
1 | [ |
从底向上更新:
1 | 第 3 层更新为: [7, 6, 10] ← 来自 [6+min(4,1), 5+min(1,8), 7+min(8,3)] |
最终结果:11
🧾 Java 实现(原地修改 triangle)
1 | class Solution { |
🔍 关键语句解释
f.get(i).get(j)
- 获取第
i行第j个元素的值,相当于二维数组中的f[i][j]
f.get(i).set(j, value)
- 将
value设置到第i行第j个位置,等同于更新f[i][j]
这句核心代码可以拆解为:
1 | int cur = f.get(i).get(j); |
⏱️ 复杂度分析
- 时间复杂度:O(n²),每个点都遍历一次
- 空间复杂度:O(1),直接在原数组中更新,无需额外空间