【优选算法】前缀和

前缀和思想其实就是一种简单的dp思想,也就是动态规划

什么时候用到前缀和?当要快速求出数组中某一个区间的和

前缀和模板

暴力解法

定义一个指针从左向右遍历,并且累加值即可,这里就不过多赘述,主要还是来看前缀和

假设查找长度为n,要查q次,那时间复杂度就是O(n*q)

前缀和

我们可以定义一个与原数组相同大小的数组dp,dp[i]表示[1,i]区间内所有元素的和

通过观察并结合dp[i]的第一可以发现规律:dp[i]=dp[i-1]+nums[i]——[1,i]区间的和等于[1,i-1]区间的和再加上nums[i]

当我们遍历完一边数组的时候,dp表也就完成了。当我们再去求[left,right]区间和的时候,发现要求的区间和等于dp[right]-dp[left-1](注意不是dp[left]),这一步的时间复杂度是O(1)的

所以时间复杂度由O(n*q)降为O(n)了

细节问题:为什么下标从1开始?

因为dp[i]=dp[i-1]+nums[i],如果从0开始就会出现-1,数组越界,不好处理,干脆从1开始方便

一维前缀和相关习题

和为K的子数组

解析

1.暴力解法

从第一个位置开始暴力枚举所有子数组——以i位置为起点的所有子数组,直到i等于size-1完成遍历

这里不过多赘述

2.前缀和

要知道和为k的子数组,肯定是要把所有数组的信息都收集到的,但是暴力枚举效率又太低了,所以要通过暴力枚举来优化

暴力枚举是遍历以i位置为起点的所有子数组,这里引入以i位置为结尾的所有子数组,这样往后遍历也是可以遍历所有子数组的

先定义前缀和数组dp,dp[i]表示[0,i]位置的子数组和,dp[i]=dp[i-1]+nums[i]

当遍历到i位置的时候,只关心dp[i]之前的子数组,目前我们知道dp[i],要求和为k的子数组

由上图可得问题可以转变成在[0,i-1]区间,有多少个前缀和等于dp[i]-k

这题如果只是建立和使用前缀和数组是远远不够的,假如你只使用前缀和数组,当cur在i位置的时候你要求有多少个前缀和等于dp[i]-k,那你还要定义一个变量prev=0,开始往后遍历到cur位置,仍然是O(N^2)的时间复杂度,还多了一次遍历数组的操作,这样还不如直接暴力枚举呢

上面的问题就是在创建前缀和数组的时候没有进行记录,所以这里要用哈希表对每个前缀和都进行记录,这样一次遍历完后就能直接获得结果

魔鬼小细节:

1.前缀和加入哈希表的时机

在计算i位置之前,哈希表里存的是[0,i-1]位置的前缀和

2.不用真正创建一个哈希表,因为这里可以发现i从左到右遍历,每个dp[i]只使用一次,因此使用一个sum表示dp[i]即可,当遍历的i+1的时候,sum+=nums[i+1]即可

3.如果整个数组的前缀和等于k呢?

那么dp[i]-k==0,所以hash[0]要默认初始化为1

参考答案

class Solution {
public:
    int subarraySum(vector<int>& nums, int k) {
    int n=nums.size(),ret=0,sum=0;
    unordered_map<int,int> hash;
    hash[0]=1;
   for(auto x:nums)
   {
       sum+=x;
       if(hash.count(sum-k))
       {
           ret+=hash[sum-k];
       }
       hash[sum]++;
   }
    return ret;
    }
};

由代码也可以看到如果出现整个数组的前缀和等于k的情况,ret是少加了一次hash[0]的情况的,所以hash[0]要默认初始化为1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/430047.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

缓存雪崩、击穿、穿透

目录 前言 一、缓存雪崩 1.大量数据同时过期 1.均匀设置过期时间 2.互斥锁 3.后台更新缓存 2.Redis故障宕机 1.服务熔断或请求限流机制 2.构建Redis缓存高可靠集群 二、缓存击穿 1.设置互斥锁&#xff1b; 2.不给热点数据设置过期时间&#xff0c;由后台更新缓存。 …

可行性研究报告-范例直接套用

1业务需求可行性分析 2技术可行性分析 2.1规范化原则 2.2高度的兼容性和可移植性 2.3人性化、适用性 2.4标准化统一设计原则 2.5先进安全可扩展性原则 3开发周期可行性分析 4人力资源可行性分析 5成本分析 6收益分析 7结论 软件开发多套实际项目案例、方案、源码获取&#xff1…

使用API有效率地管理Dynadot域名,进行DNS域名解析

关于Dynadot Dynadot是通过ICANN认证的域名注册商&#xff0c;自2002年成立以来&#xff0c;服务于全球108个国家和地区的客户&#xff0c;为数以万计的客户提供简洁&#xff0c;优惠&#xff0c;安全的域名注册以及管理服务。 Dynadot平台操作教程索引&#xff08;包括域名邮…

nodejs,JSDOM 补 window环境

window[atob] 是一个在浏览器中使用的 JavaScript 函数&#xff0c;用于将 base64 编码的字符串解码为原始数据。具体来说&#xff0c;atob 函数会将 base64 字符串解码为一个 DOMString&#xff0c;其中包含解码后的二进制数据。这在处理从服务器获取的 base64 编码的数据或在…

RedisDesktopManager连接Ubuntu的Redis失败解决办法

配置redis 1.设置redis在后台服务&#xff0c;修改配置文件 默认情况下是 no ,修改为yes&#xff0c;可以后台服务 2、设置redis端口&#xff0c;默认端口是6379&#xff0c;可以根据自己的需要&#xff0c;找到/et/redis/redis.conf文件, 修改port 3、设置密码 配置文件中…

基于pytorch的手写体识别

一、环境搭建 链接: python与深度学习——基础环境搭建 二、数据集准备 本次实验用的是MINIST数据集&#xff0c;利用MINIST数据集进行卷积神经网络的学习&#xff0c;就类似于学习单片机的点灯实验&#xff0c;学习一门机器语言输出hello world。MINIST数据集&#xff0c;可以…

【书籍推广】这本书太好了!150页就能让你上手大模型应用开发

文章目录 蛇尾书特色蛇尾书思维导图作译者简介业内专家书评 如果问个问题&#xff1a;有哪些产品曾经创造了伟大的奇迹&#xff1f;ChatGPT 应该会当之无愧入选。仅仅发布 5 天&#xff0c;ChatGPT 就吸引了 100 万用户——当然&#xff0c;数据不是关键&#xff0c;关键是其背…

【Unity】VR开发的正确测试节奏

【背景】 VR开发由于其测试时对设备的依赖较大&#xff0c;因此有时在没有测试条件时想当然地写了大量代码&#xff0c;一旦到正式测试时需要debug&#xff0c;往往无法判断到底是哪个环节的问题&#xff08;代码&#xff0c;环境&#xff0c;等等&#xff09;。相对于PC平台的…

AI预测福彩3D第2弹【2024年3月5日预测】

书接上回&#xff0c;首先声明下&#xff0c;写这一系列文章的目的不为别的&#xff0c;就是想看下到底使用一些强大的AI算法能不能挖掘出彩票的规律&#xff0c;毕竟彩票的规律太乱&#xff0c;不是说没有规律&#xff0c;而是规律太多。经过上一篇文章的图片&#xff0c;大家…

git使用教程14-Pycharm版本控制与分支管理

一、版本控制 1、版本控制介绍 &#xff08;1&#xff09;Version Control System 版本控制系统&#xff0c;简称VCS。 &#xff08;2&#xff09;版本控制系统分类&#xff1a; 集中式版本控制工具&#xff1a;SVN 分布式版本控制工具&#xff1a;Git 2、Pycharm 支持的版本…

C++:Vector的使用

一、vector的介绍 vector的文档介绍 1. vector是表示可变大小数组的序列容器。 2. 就像数组一样&#xff0c;vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问&#xff0c;和数组一样高效。但是又不像数组&#xff0c;它的大小是可以…

全链路监控

1. 全链路监控的兴起与发展 当代的互联网的服务&#xff0c;通常都是用复杂的、大规模分布式集群来实现的。互联网应用构建在不同的软件模块集上&#xff0c;这些软件模块&#xff0c;有可能是由不同的团队开发、可能使用不同的编程语言来实现、有可能布在了几千台服务器&…

CentOS 7操作系统安装教程

CentOS 7操作系统安装教程 CentOS 7是一款功能强大、稳定可靠的操作系统&#xff0c;适用于服务器、桌面等多种场景。下面将介绍CentOS 7的安装教程。 准备工作 下载CentOS 7镜像文件&#xff1a;https://mirrors.tuna.tsinghua.edu.cn/centos/7/isos/x86_64/准备安装介质&am…

【新书推荐】13.2 应用举例

本节内容&#xff1a;磁盘文件管理功能号调用应用举例。 ■例1&#xff1a;显示文本文件内容t13-1.asm。 ■例2&#xff1a;将键盘输入字符存入文件t13-2.asm。 ■例3&#xff1a;文件拼接t13-3.asm。 13.2.1 例1&#xff1a;显示文本文件内容 动手实验93&#xff1a;写一个…

Centos 9 安装 k8s

为了尽可能契合生产环境的部署情况&#xff0c;这里用kubeadm安装集群&#xff0c;同时方便跟随笔记一步步实践的过程&#xff0c;也更加了解k8s的一些特性和基础知识。 先决条件 这里将通过虚拟机安装3台centos stream 9服务器&#xff0c;并组成kubeneters集群&#xff08;…

如何在MinIO系统中进行配置并结合内网穿透实现公网远程连接上传文件

文章目录 前言1. 创建Buckets和Access Keys2. Linux 安装Cpolar3. 创建连接MinIO服务公网地址4. 远程调用MinIO服务小结5. 固定连接TCP公网地址6. 固定地址连接测试 前言 MinIO是一款高性能、分布式的对象存储系统&#xff0c;它可以100%的运行在标准硬件上&#xff0c;即X86等…

ROS2中std_msgs/msg/Header 数据含义及使用

ROS2中std_msgs/msg/Headerr 数据含义及使用 ROS官方消息说明数据说明使用ros2标准的Header案例代码解释测试结果 ROS官方消息说明 ROS2中std_msgs消息包含类型 https://docs.ros2.org/latest/api/std_msgs/msg/std_msgs/msg/Header Message std_msgs/msg/Header数据格式&…

“零碳未来”:引领全球向低碳经济转型

全球环境基金(GEF),这个由183个国家和地区组成的国际合作组织,是世界银行1990年创建的实验项目,一直致力于支持环境友好型项目,推动全球环境改善。而“零碳未来”不仅是一个由全球环境基金(GEF)创建的跨越国界的全新交易平台,更是一个致力于推动全球向低碳经济转型的零碳排放生…

ChromeDriver全版本下载教程

确定自己的Chrome版本 step1. 打开Chrome浏览器右上角的三个点&#xff0c;再点击设置 step2. 在设置中点击“关于Chrome”&#xff0c;圈起来的红框即为当前Chrome版本&#xff0c;我的版本就是121.0.6167.185 在json中查找自己对应ChromeDriver版本下载链接 一般教程会让你…

2_SQL

文章目录 SQL数据完整性实体完整性域完整性参照完整性default&#xff08;默认值&#xff09;comment&#xff08;注释&#xff09; 多表设计一对一一对多多对多数据库三大范式第一范式&#xff1a;原子性第二范式&#xff1a;唯一性第三范式&#xff1a;数据的冗余 多表查询连…