news 2026/4/17 8:52:13

力扣 500 和为 K 的子数组

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣 500 和为 K 的子数组
Problem: 560.和为 K 的子数组

思路

前缀和 + 小技巧

解题过程

题目大意可以理解为,让找一个数组中的连续非空子数组的和为k的数量。
这里可以使用前缀和数组suf[]来快速找到符合条件的子数组头和尾。因为一个子数组(i,j)的大小为suf[j] - suf[i-1],因此我们这里只需要找到suf[j] - suf[i-1] = k的两个数,那么题目就变成找到两个数的差为k。那么显而易见可以用哈希来找。
这里有个小技巧,我一开始存储的哈希是把suf[i]和i一起存了,于是变得判断当前的i是否大于哈希找出来的i(因为j>i-1),就得多个查找过程,这样可能会超时,后面发现直接边查边存就不会有这种问题了,这个小技巧适用于查找过程中有下标大小影响的时候,因为ii比当前下班大的下标的数据还未存入,所以这个时候查询只会查找到比当前下标小的数据。

复杂度

  • 时间复杂度: O(n)
  • 空间复杂度:O(n)

Code

class Solution { public int subarraySum(int[] nums, int k) { int len = nums.length; int[] suf = new int[len + 1]; for(int i = 0; i < len; i++) { suf[i + 1] = nums[i] + suf[i]; } Map<Integer,Integer> map = new HashMap<>(); int ans = 0; for(int i = 0; i <= len; i++) { int dif = suf[i] - k; ans += map.getOrDefault(dif, 0); map.merge(suf[i], 1, Integer::sum); } return ans; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 5:44:25

5 分钟快速入门 Gitlab CI/CD

&#x1f680; 快速掌握 GitLab CI/CD&#xff1a;自动化你的开发流程 GitLab CI/CD 是一个功能强大的工具&#xff0c;它内置于 GitLab 中&#xff0c;用于自动化你的软件构建、测试和部署流程。如果你希望提升开发效率、减少人为错误并实现持续集成/持续部署&#xff08;CI/…

作者头像 李华
网站建设 2026/4/18 5:34:49

毕业论文选题AI推荐:9大工具+热门方向合集

毕业论文选题AI推荐&#xff1a;9大工具热门方向合集 &#xfffd;&#xfffd; 核心AI工具对比速览 工具名称 核心功能 适用场景 生成速度 特色优势 aibiye 初稿生成/降重/格式优化 全学科通用 20-30分钟 支持理工科图表公式自动插入 aicheck 选题推荐/查重/AIGC检…

作者头像 李华
网站建设 2026/4/16 18:42:21

Java毕业设计做不出来可以找代做吗?

这是一个非常敏感且重要的问题&#xff0c;我需要给你最负责任、最真诚的回答。直接答案&#xff1a;强烈不建议&#xff0c;风险极高&#xff0c;有百害而无一利。我理解你现在可能感到焦虑和无助&#xff0c;但寻找代做是一条会让你陷入更大麻烦的危险捷径。让我详细分析一下…

作者头像 李华
网站建设 2026/4/15 8:50:13

javet 的使用

第一版使用的是j2v8,但是已经不维护了,部署到liunx后报错 J2V8 native library not loaded ,之后切换到这个库了 https://github.com/caoccao/Javenode 引入依赖 <!-- Core (Must-have) --><dependency><groupId>com.caoccao.javet</groupId><art…

作者头像 李华
网站建设 2026/4/16 15:44:22

Stop-motion-OBJ:Blender网格序列动画导入终极指南

Stop-motion-OBJ&#xff1a;Blender网格序列动画导入终极指南 【免费下载链接】Stop-motion-OBJ A Blender add-on for importing a sequence of OBJ meshes as frames 项目地址: https://gitcode.com/gh_mirrors/st/Stop-motion-OBJ Stop-motion-OBJ是一款功能强大的B…

作者头像 李华