题目简介:
我们有两个长度相等且不为空的整型数组 nums1
和 nums2
。在一次操作中,我们可以交换 nums1[i]
和 nums2[i]
的元素。
- 例如,如果
nums1 = [1,2,3,8]
,nums2 = [5,6,7,4]
,你可以交换i = 3
处的元素,得到nums1 =[1,2,3,4]
和nums2 =[5,6,7,8]
。
返回 使 nums1
和 nums2
严格递增 所需操作的最小次数 。
数组 arr
严格递增 且 arr[0] < arr[1] < arr[2] < ... < arr[arr.length - 1]
。
注意:
- 用例保证可以实现操作。
示例 1:
1 | 输入: nums1 = [1,3,5,4], nums2 = [1,2,3,7] |
提示:
2 <= nums1.length <= 10^5
nums2.length == nums1.length
0 <= nums1[i], nums2[i] <= 2 * 10^5
思路:
动态规划,dp[i][0]
代表到i
为止,能使nums1, nums2
满足严格递增且位置i
不进行交换操作的最小操作数;
dp[i][1]
代表到i
为止,能使nums1, nums2
满足严格递增且位置i
进行交换操作的最小操作数。
由于题目保证题目用例可以实现操作,所以位置i
必满足以下两种情况之一:
nums1[i] > nums1[i - 1] && nums2[i] > nums2[i - 1]
nums1[i] > nums2[i - 1] && nums2[i] > nums1[i - 1]
当满足1不满足2时:
dp[i][0] = dp[i - 1][0]
dp[i][1] = dp[i - 1][1] + 1
当满足2不满足1时:
dp[i][0] = dp[i - 1][1]
dp[i][1] = dp[i - 1][0] + 1
同时满足1,2时:
dp[i][0] = min(dp[i - 1][0], dp[i - 1][1])
dp[i][1] = min(dp[i - 1][1] + 1, dp[i - 1][0] + 1)
代码如下:
1 | class Solution { |