题目简介:
我们有两个长度相等且不为空的整型数组 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^5nums2.length == nums1.length0 <= 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 { |