Java怎么找到和为K的子数组
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,本篇内容主要讲解"Java怎么找到和为K的子数组",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Java怎么找到和为K的子数组"吧!前序和定义sum[i]表
千家信息网最后更新 2025年02月03日Java怎么找到和为K的子数组
本篇内容主要讲解"Java怎么找到和为K的子数组",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Java怎么找到和为K的子数组"吧!
前序和
定义sum[i]表示从开始加到第i位置的和,在数组[1,2,3,4]上我们就有
sum[0] = nums[0]
sum[1] = nums[0] + nums[1] = sum[0] + nums[1]
sum[2] = nums[0] + nums[1] + nums[2] = sum[0] + nums[1] + nums[2] = sum[1] + nums[2]
sum[3] = nums[0] + nums[1] + nums[2] +nums[3] = sum[0] + nums[1] + nums[2] + nums[3] = ... ...
我们发现,我们做了很多重复的计算,这些就是我们可以优化的地方,对上面第3个式子进行一下变形,
sum[1]-sum[0]=nums[1]
sum[2] - sum[0] = nums[1] + nums[2]
sum[2] - sum[1] = nums[2]
sum[i] - sum[j] 就是(j+1,i)之间连续数组的和,如果sum[i] - sum[j] = k,那我们就可以进行计数了,这里也可以进行一次变形sum[j] = sum[i] - k,我们使用哈希表来记录sum[j],再次出现的时候我们就进行计数。
func subarraySum(nums []int, k int) int { res,sum,m :=0,0, map[int]int{0:1} for i:=0;i0{ res += m[sum-k] } m[sum]++ } return res}
到此,相信大家对"Java怎么找到和为K的子数组"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
数组
内容
就是
学习
实用
更深
之间
位置
兴趣
再次
地方
实用性
实际
式子
操作简单
方法
时候
更多
朋友
网站
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
海南前端软件开发
数据库 2008登录
服务器标准机箱
和消费相关的数据库
华为账号连接不上率土之滨服务器
刺激战场微信服务器怎么关闭
海康视频服务器管理后台
行业分析数据库
胶州市网亿游网络技术工作室
学校网络安全教育通讯
数据库制作模板软件
数据库系统软件制作
省网络安全协会是什么机构
excl怎么复制公式数据库
快捷输入app软件开发
北京软件开发学习班
苏州戴尔服务器优点对比
人脸速通门管理服务器型号
商国互联网科技有限公司招聘
李彦宏网络安全办
36岁从运维转网络安全
维护网络安全的重要性是什么
三星网络技术学院
博库数据库账号
能源部数据库ST
汉阳订制软件开发价格
网络安全的第一负责人是谁
超市标签数据库
翻译软件开发创业计划书
域服务器管理员账号是什么