3.构造最长非递减子数组 7月9日周赛

解法

假设每个位置为最后合成数组的最长子数组的开头。
因此,枚举每个位置的最长子数组
第一个位置肯定取最小值,之后 i i i的数值,如果 n u m s 1 [ i ] nums1[i] nums1[i] n u m s 2 [ i ] nums2[i] nums2[i]都大于等于先前的数字 p r e pre pre,那么就取 m i n ( n u m s 1 [ i ] , n u m s 2 [ i ] ) min(nums1[i], nums2[i]) min(nums1[i],nums2[i]),如果都小于,那么直接 b r e a k break break。否则就说明 p r e pre pre的数值在 n u m s 1 [ i ] nums1[i] nums1[i] n u m s 2 [ i ] nums2[i] nums2[i]的中间,因此,取大于 p r e pre pre的数值。
剪枝

  1. 如果剩下的数组元素个数要小于当前的最大长度 a n s ans ans,直接 b r e a k break break
  2. 如果第 i i i位的元素都大于第 i − 1 i-1 i1位元素的最小值,那么说明前面的最大子数组长度包括以当前开头的子数组长度,可以跳过。

Code

class Solution:
    def maxNonDecreasingLength(self, nums1: List[int], nums2: List[int]) -> int:
        # 假设每个位置的数字为最长子数组的开头
        ans = 0
        n = len(nums1)
        for i in range(n):
            pre = -1
            cur_len = 0
            if ans >= n - i:
                break
            if i > 0 and min(nums1[i], nums2[i]) > min(nums1[i - 1], nums2[i - 1]):
                continue
            for j in range(i, n):
                if min(nums1[j],nums2[j]) >= pre:
                    pre = min(nums1[j], nums2[j])
                    cur_len += 1
                elif max(nums1[j], nums2[j]) < pre:
                    break
                else:
                    pre = max(nums1[j], nums2[j])
                    cur_len += 1
            ans = max(ans, cur_len)
        return ans
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值