IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 第14题 力扣LeetCode 热题 HOT 100(560. 和为K的子数组) -> 正文阅读

[数据结构与算法]第14题 力扣LeetCode 热题 HOT 100(560. 和为K的子数组)

第14题 力扣LeetCode 热题 HOT 100(560. 和为K的子数组)

题目

给定一个整数数组和一个整数 **k,**你需要找到该数组中和为 k 的连续的子数组的个数。

示例 1 :

输入:nums = [1,1,1], k = 2
输出: 2 , [1,1] 与 [1,1] 为两种不同的情况。

说明 :

  1. 数组的长度为 [1, 20,000]。
  2. 数组中元素的范围是 [-1000, 1000] ,且整数 k 的范围是 [-1e7, 1e7]。

题解

首先想到的当然是两重for循环,遍历得到两个节点之间的和,时间复杂度O(n^2)过不了,看了一眼数据范围,暴力过不了。。。想不出来优化方案,看了力扣的题解

时间复杂度O(n)的方案,遍历中累加得到当前下标的前缀和,然后把当前下标的前缀和用出现的次数表示,保存进哈希表中

就是遍历过程中,当遍历到某个下标时,当前元素和元素之前的数组中的元素构成一段。

这一段中分为两部分,其中是前面的一部分(从0开始到某个下标),后面一部分(某个下标后到当前遍历元素中的下标),要求后面一部分的和为目标值,即,前面一部分的值要求等于当前元素的前缀和减去目标值。

/**
 * @param {number[]} nums
 * @param {number} k
 * @return {number}
 */
var subarraySum = function(nums, k) {
    let result = 0;
    // let sum = nums[0];
    let map = new Map();
    let arr = [];
    let sum=0;
    map.set(0,1);
    for(let i = 0; i< nums.length; i++){
        sum = sum+ nums[i];
        if(map.get(sum-k)){
           result= result+map.get(sum-k);
        };
        arr.push(sum);
        if(map.get(sum)){
            map.set(sum, map.get(sum)+1);
        }else{
            map.set(sum, 1);
        }
    }
    return result;
};
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-08-19 12:18:53  更:2021-08-19 12:19:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 21:37:51-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码