Leetcode 2875. Minimum Size Subarray in Infinite Array

  • [Leetcode 2875. Minimum Size Subarray in Infinite Array](#Leetcode 2875. Minimum Size Subarray in Infinite Array)
    • [1. 解题思路](#1. 解题思路)
    • [2. 代码实现](#2. 代码实现)

1. 解题思路

这一题的话首先由于数组可以无限延伸,因此如果target大于array的总和,那么一定是通过多次循环获得的,因此我们可以提前算好loop数,然后将target变成一组循环里面可能获得的数。

然后,我们就是看怎么最快的得到这个数,这个我们可以通过累积数组来完成,要获得这个target数,只可能是两种情况:

  1. 一组循环内,存在后续某个index上的数使得两者之间的数组之和为target;
  2. 直接取到末尾然后不够的数字从头上进行补充。

我们只需要分别考虑这两种情况,然后将其中可能的实现的方式对应的数组长度进行一下计算然后取最短长度即可。

2. 代码实现

给出python代码实现如下:

python 复制代码
class Solution:
    def minSizeSubarray(self, nums: List[int], target: int) -> int:
        n = len(nums)
        s = sum(nums)
        loop = (target // s) * n
        target = target % s
        
        accums = [0] + list(accumulate(nums))
        index = {x: i for i, x in enumerate(accums)}

        res = n+1
        for i, x in enumerate(accums):
            if x + target in index:
                res = min(res, index[x + target] - i)
            if target-(s-x) in index:
                res = min(res, index[target-(s-x)] + n-i)
        return res + loop if res != n+1 else -1

提交代码评测得到:耗时323ms,占用内存36.4MB。

相关推荐
LYFlied15 分钟前
【每日算法】LeetCode 70. 爬楼梯:从递归到动态规划的思维演进
算法·leetcode·面试·职场和发展·动态规划
一起养小猫16 分钟前
LeetCode100天Day2-验证回文串与接雨水
java·leetcode
YoungHong199219 分钟前
面试经典150题[073]:从中序与后序遍历序列构造二叉树(LeetCode 106)
leetcode·面试·职场和发展
业精于勤的牙23 分钟前
浅谈:算法中的斐波那契数(五)
算法·leetcode·职场和发展
LYFlied1 小时前
【每日算法】LeetCode 105. 从前序与中序遍历序列构造二叉树
数据结构·算法·leetcode·面试·职场和发展
DanyHope1 小时前
LeetCode 206. 反转链表:迭代 + 递归双解法全解析
算法·leetcode·链表·递归·迭代
DanyHope1 小时前
LeetCode 两数之和:从 O (n²) 到 O (n),空间换时间的经典实践
前端·javascript·算法·leetcode·职场和发展
DanyHope1 小时前
LeetCode 283. 移动零:双指针双解法(原地交换 + 覆盖补零)全解析
数据结构·算法·leetcode
LYFlied2 小时前
【每日算法】LeetCode 114. 二叉树展开为链表:从树结构到线性结构的优雅转换
数据结构·算法·leetcode·链表·面试·职场和发展
hh随便起个名11 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode