和等于 k 的最长子数组长度(LeetCode)

题目

给定一个数组 nums 和一个目标值 k,找到和等于*k* 的最长连续子数组长度。如果不存在任意一个符合要求的子数组,则返回 0

解题

python 复制代码
"""
时间复杂度: O(n),因为我们只遍历一次数组。
空间复杂度: O(n),用于存储前缀和及其对应的位置。
"""


def maxSubArrayLen(nums, k):
    prefix_sums = {0: -1}  # 初始化哈希表,前缀和为 0 时索引为 -1
    current_sum = 0
    max_length = 0

    for i, num in enumerate(nums):
        current_sum += num

        # 检查是否存在前缀和,使得 current_sum - previous_sum = k
        if current_sum - k in prefix_sums:
            max_length = max(max_length, i - prefix_sums[current_sum - k])

        # 仅在哈希表中记录前缀和首次出现的位置
        if current_sum not in prefix_sums:
            prefix_sums[current_sum] = i

    return max_length


# 示例 1
nums = [1, -1, 5, -2, 3]
k = 3
print(maxSubArrayLen(nums, k))  # 输出: 4

# 示例 2
nums = [-2, -1, 2, 1]
k = 1
print(maxSubArrayLen(nums, k))  # 输出: 2
相关推荐
浪客灿心1 分钟前
list_stack_queue
数据结构·list
zh_xuan4 分钟前
最小跳跃次数
数据结构·算法
yumgpkpm14 分钟前
2026软件:白嫖,开源,外包,招标,晚进场(2025年下半年),数科,AI...中国的企业软件产业出路
大数据·人工智能·hadoop·算法·kafka·开源·cloudera
m0_7066532317 分钟前
用Python批量处理Excel和CSV文件
jvm·数据库·python
Yvonne爱编码17 分钟前
JAVA数据结构 DAY5-LinkedList
java·开发语言·python
witAI20 分钟前
**AI漫剧制作工具2025推荐,零成本实现专业级动画创作*
人工智能·python
孞㐑¥22 分钟前
算法—队列+宽搜(bfs)+堆
开发语言·c++·经验分享·笔记·算法
yufuu9831 分钟前
并行算法在STL中的应用
开发语言·c++·算法
zh_xuan31 分钟前
单青蛙跳台阶
数据结构·算法
Kx_Triumphs37 分钟前
计算几何-旋转卡壳两种实现方案(兼P1452题解
算法·题解