力扣精选算法100道——【模板】前缀和(一维)

【模板】前缀和_牛客题霸_牛客网 (nowcoder.com)

目录

🚩了解题意

🚩算法原理

🎈设定下标为1开始

🎈取值的范围

🚩实现代码


🚩了解题意

第一行的3和2,3代表行数,2代表q次查询(查询的次数)

第二行 1 2 4 表示 n=3个整数 (长度为n的数组各个数)

第三行和第四行(有几行代表几次查询) 分别是1,2和 2,3 

  • (1,2)代表第一次查询 从1到2(这里我们需要注意下标要从1开始)所以我们相加的是1+2=3   第一次结果是3。
  • (2,3)代表第二次查询从2到3 所以相加的是2+4=6  第二次结果是6.

🚩算法原理

如果有q次查询,我们需要依次q--,再一次循环中依次输入l和r的值。

  1. 输入:从标准输入中读取两个整数 nq,分别表示数组的大小和查询的次数。
  2. 数组初始化:创建一个大小为 n+1 的数组 arr,用于存储输入的数组元素。同时创建一个大小为 n+1 的数组 dp,用于存储前缀和。注意,数组从索引 1 开始存储元素,而不是从 0 开始。
  3. 计算前缀和:遍历输入的数组元素,计算每个位置 i 的前缀和,并存储在 dp[i] 中。具体做法是,对于每个位置 i,将前 i 个元素的和累加到 dp[i] 中。这样,dp[i] 就表示数组前 i 个元素的和。
  4. 处理查询:循环 q 次,每次读取一个查询的左右边界 lr。然后,通过前缀和数组 dp,计算子数组 arr[l...r] 的和,即 dp[r] - dp[l-1]。这是因为 dp[r] 包含了 arr[1...r] 的和,而 dp[l-1] 包含了 arr[1...l-1] 的和,两者相减即可得到 arr[l...r] 的和。
  5. 输出结果:将每次查询得到的子数组和输出到标准输出中。

🎈设定下标为1开始

我们需要将下标设定是1开始的,我们平常的数组定义是第一个数的下标是0,而这里我们需要手动设定下标从1开始   vector<int>(n+1)

数组初始化:创建一个大小为 n+1 的数组 arr,用于存储输入的数组元素。同时创建一个大小为 n+1 的数组 dp,用于存储前缀和。注意,数组从索引 1 开始存储元素,而不是从 0 开始。

🎈取值的范围

这里我们看到数组中的取值是-10^9~10^9,所以我们需要用到long long 而不是int类型


🚩实现代码

#include <iostream>
#include<vector>
using namespace std;
int main()
{long long n,q;cin>>n>>q;vector<long long>arr(n+1);for(long long i=1;i<=n;i++)cin>>arr[i];//2.预处理一个前缀和数组vector<long long>dp(n+1);for(long long i=1;i<=n;i++)dp[i]=dp[i-1]+arr[i];//3.使用前缀和数组long long l=0,r=0;while(q--){cin>>l>>r;cout<<dp[r]-dp[l-1]<<endl;}return 0;
}

不要过度美化没走的那条路。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

每日五道java面试题之java基础篇(七)

第一题. HashMap和HashTable有什么区别&#xff1f;其底层实现是什么&#xff1f; 区别 &#xff1a; HashMap⽅法没有synchronized修饰&#xff0c;线程⾮安全&#xff0c;HashTable线程安全&#xff1b;HashMap允许key和value为null&#xff0c;⽽HashTable不允许 底层实现…

在Ubuntu22.04上部署FoooCUS2.1

Fooocus 是一款基于 Gradio的图像生成软件&#xff0c;Fooocus 是对 Stable Diffusion 和 Midjourney 设计的重新思考&#xff1a; 1、从 Stable Diffusion 学习&#xff0c;该软件是离线的、开源的和免费的。 2、从 Midjourney 中学到&#xff0c;不需要手动调整&#xff0c;…

langchain==win11搭建使用GPU

annaconda安装Python 3.11.7 下载代码&#xff1a; GitHub - chatchat-space/Langchain-Chatchat: Langchain-Chatchat&#xff08;原Langchain-ChatGLM&#xff09;基于 Langchain 与 ChatGLM 等语言模型的本地知识库问答 | Langchain-Chatchat (formerly langchain-ChatGLM)…

从零开始学howtoheap:理解fastbins的​unsorted bin攻击

how2heap是由shellphish团队制作的堆利用教程&#xff0c;介绍了多种堆利用技术&#xff0c;后续系列实验我们就通过这个教程来学习。环境可参见从零开始配置pwn环境&#xff1a;从零开始配置pwn环境&#xff1a;从零开始配置pwn环境&#xff1a;优化pwn虚拟机配置支持libc等指…

在程序中使用日志功能

在应用中&#xff0c;需要记录程序运行过程中的一些关键信息以及异常输出等。这些信息用来排查程序故障或者其他用途。 日志模块可以自己实现或者是借用第三方库&#xff0c;之前写过一个类似的使用Qt的打印重定向将打印输出到文件&#xff1a;Qt将打印信息输出到文件_qt log输…

牛客——递归实现指数型枚举(枚举,dfs)

链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 来源&#xff1a;牛客网 题目描述 从 1∼n1\sim n1∼n这 n (n≤16)(n \leq 16)(n≤16) 个整数中随机选取任意多个&#xff0c;输出所有可能的选择方案。 输入描述: 一个整数n。 输出描述: 每行一种方案。同一行内…

第6个-滚动动画

Day 6 - Scroll Animation 1. 演示效果 2. 分析思路 布局 所有的内容进行水平垂直居中&#xff0c;可以使用**margin:0 auto;&#xff0c;也可以使用flex**布局&#xff1a; body {background-color: #efedd6;display: flex;flex-direction: column;justify-content: center…

【Algorithms 4】算法(第4版)学习笔记 07 - 2.4 优先队列

文章目录 前言参考目录学习笔记1&#xff1a;API1.1&#xff1a;实现 demo 示例1.2&#xff1a;初级实现&#xff08;有序或无序的数组&#xff09;2&#xff1a;二叉堆2.1&#xff1a;完全二叉树2.2&#xff1a;二叉堆2.2.1&#xff1a;堆的表示2.2.2&#xff1a;属性2.3&…

controller-manager学习三部曲之三:deployment的controller启动分析

欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码)&#xff1a;https://github.com/zq2599/blog_demos 《controller-manager学习三部曲》完整链接 通过脚本文件寻找程序入口源码学习deployment的controller启动分析 本篇概览 本文是《controller-manager学习三…

链表基础知识汇总

链表 链表是一种基本的数据结构&#xff0c;是由一系列节点组成的集合。每个节点包含两个部分&#xff1a;值和指向下一个节点的指针。链表中的节点可以动态地添加、删除&#xff0c;其大小可以根据需要进行扩展或缩小。 链表通常用于处理不固定长度的数据结构&#xff0c;具有…

【数据结构】常见八大排序算法(附动图)

一、前言 关于排序&#xff0c;有一些术语&#xff0c;例如算法的稳定/不稳定&#xff0c;内部排序和外部排序等&#xff0c;需要我们了解一下 稳定&#xff1a;当未排序时a在b前面且ab&#xff0c;排序后a仍然在b前面 不稳定&#xff1a;当未排序时a在b前面且ab&#xff0c;排…

专业课145+总分400+天津大学815信号与系统考研经验天大电子信息与通信工程,真题,大纲,参考书。

今年专业课145&#xff08;差一点满分&#xff0c;有点遗憾&#xff09;总分400&#xff0c;顺利被天津大学录取&#xff0c;应群里学弟学妹的要求总结了过去这一年我的复习经验&#xff0c;希望对大家有所借鉴。专业课&#xff1a; 815信号与系统145差一点满分&#xff0c;也…