【力扣 Hot100 | 第八天】4.23(和为K的子数组)

news/2024/9/25 16:07:08/

在这里插入图片描述

1.和为K的子数组

1.1题目

给你一个整数数组 nums 和一个整数 k ,请你统计并返回 该数组中和为 k 的子数组的个数

子数组是数组中元素的连续非空序列。

  • 示例一:
输入:nums = [1,1,1], k = 2
输出:2
  • 示例二:
输入:nums = [1,2,3], k = 3
输出:2

1.2解法:前缀和+哈希

1.2.1解法思路

  • 核心思想:
    • 使用前缀和的概念:对于数组中的任意连续子数组,可以通过计算前缀和来快速得到该子数组的和。
    • 维护一个HashMap,其中键表示前缀和,值表示该前缀和出现的次数。
    • 在遍历数组过程中,不断更新前缀和,并计算当前前缀和与目标值k的差值,然后查看HashMap中是否存在该差值,若存在,则表示存在和为k的子数组。
  • 代码解释:
    • count:用于记录和为k的子数组的数量。
    • pre:用于记录当前的前缀和。
    • mp:HashMap,用于存储前缀和及其出现的次数。
    • 遍历数组nums,对于每个元素:
      • 更新前缀和pre,并计算当前前缀和与目标值k的差值。
      • 若HashMap中存在该差值,则将该差值对应的出现次数累加到count中。
      • 更新HashMap中当前前缀和的出现次数。
    • 最终返回count,即和为k的子数组的数量。
  • 举例如下:

image-20240423090057786

1.2.2代码实现

java">	public int subarraySum(int[] nums, int k) {int pre=0;      //前缀和Map<Integer,Integer> map=new HashMap<>();   //存放key为前缀和,value为该前缀和出现的情况map.put(0,1);   //前缀和为0的情况有1种,即空数组int count=0;    //和为k的子数组的总数量for(int i=0;i<nums.length;i++){pre+=nums[i];if(map.containsKey(pre-k)){//count 加上 map包含pre与k的差值()count+=map.get(pre-k);}map.put(pre,map.getOrDefault(pre,0)+1);}return count;}

在这里插入图片描述


http://www.ppmy.cn/news/1440552.html

相关文章

打造智能语音机器人-用语音控制机器人

人工智能现已成为国家发展重大战略&#xff0c;智能语音技术作为人工智能产业链上的关键一环&#xff0c;AI应用成熟的技术之一&#xff0c;人工智能的发展也进入了一个崭新的阶段。那么打造智能语音机器人怎样实现用语音控制机器人呢&#xff1f;和小编一起来看看。 选择合适的…

K8S探针分享

一&#xff0c;探针介绍 1 探针类型 livenessProbe&#xff1a;存活探针&#xff0c;用于判断容器是不是健康&#xff1b;如果探测失败&#xff0c;Kubernetes就会重启容器。 readinessProbe&#xff1a;就绪探针&#xff0c;用于判断是否可以将容器加入到Service负载均衡池…

数字旅游引领智慧化浪潮:科技创新重塑旅游体验,智慧服务打造旅游新高度

在科技飞速发展的今天&#xff0c;数字旅游正以其独特的魅力引领着智慧化浪潮&#xff0c;深刻改变着旅游行业的面貌。数字技术的广泛应用&#xff0c;不仅为旅游行业注入了新的活力&#xff0c;也极大地提升了旅游体验的品质。科技创新与智慧服务的融合&#xff0c;正推动着旅…

Flutter 扒一扒图片缓存框架cached_network_image

我分析图片加载流程&#xff0c;不是直接从Image这个类开始分析的。我现拿 cached_network_image ^3.2.3这个图片缓存框架进行解析。其实cached_network_image这个框架本质上还是处理Image类的&#xff0c;往下看就知道了&#xff0c;只是cached_network_image这个框架对他进行…

MySQL中的Performance Schema是什么?

MySQL中的Performance Schema是什么&#xff1f; Performance Schema 是 MySQL 的一个特性&#xff0c;主要用于监控 MySQL 服务器在运行时的性能和资源使用情况。它首次引入于 MySQL 5.5 版本&#xff0c;并在后续版本中得到增强。Performance Schema 提供了一种方式来收集数…

直播任我行,智享AI自动直播手机塑造直播新风潮,引领行业“风口”

直播任我行&#xff01;智享AI自动直播手机塑造直播新风潮&#xff0c;引领行业“风口”&#xff01; 直播作为一种受欢迎的互联网传播方式&#xff0c;如今在帮助商家推广产品并获得更多收益方面发挥着重要作用。 在直播电商领域&#xff0c;主播是连接品牌和用户之间的关键纽…

速卖通自养号测评:如何规避安全风险?

对于初涉电商领域的新卖家而言&#xff0c;进行销量测评显得尤为关键。由于速卖通新店铺往往难以获得平台活动的支持&#xff0c;流量也相对匮乏&#xff0c;因此&#xff0c;开店的首要任务便是进行测评&#xff0c;通过积累一定的评论和销售数据。 测评的益处颇多&#xff0…

2024深圳杯(东三省)数学建模挑战赛D题:音板的振动模态分析与参数识别思路代码成品论文分析

​ 更新完整代码和成品完整论文 《2024深圳杯&东三省数学建模思路代码成品论文》↓↓↓ https://www.yuque.com/u42168770/qv6z0d/zx70edxvbv7rheu7?singleDoc# 问题重述 深圳杯&#xff08;东三省&#xff09;数学建模挑战赛2024D题&#xff1a;音板的振动模态分析与…