【算法集训】基础算法:前缀和 | 概念篇

前缀和就是对于顺序表(数组、列表)来说,计算前面某一段元素的和。

1、部分和

给定一个数组,求某一段子数组的和。

2、朴素做法

int partialSum(int *a, int l, int r) {int i;int s = 0;for(i = l; i <= r; ++i) {s += a[i];}return s;}

如果这样求lr的和的话,假设数组的长度为n,时间复杂度为O(n)

3、前缀和

这时可以用前缀和来表示。
sum[i]表示为:

sum[i - 1]表示为:

可以得到:

4、边界值问题

需要定义一个边界,不能取到的数,否则会出错。

sum[1] 表示的是从 第0项 累加到 第1项; sum[0] 表示的是从 第0项 累加到 第0项;sum[-1] 表示的是一项都没有累加,那么这个值自然就是零了。即:

5、边界处理

这时候,我们需要注意 C/C++ 中的 下标是从零开始的,所以,sum[-1] 会导致数组下标越界,可以将它转换成函数的形式将数组 sum[] 进行一次封装:

int prefixSum(int n) {if(n == -1) {return 0;}return sum[n];
}

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

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

相关文章

docker-compose安装jenkins

1、环境准备&#xff1a;准备安装好docker的服务器一台 2、在服务器上创建一个目录用于安装Jenkins mkdir jenkins3、下载好要挂载的&#xff1a;maven、jkd&#xff1b;并将下载好的tar.gz包上传至服务器待安装目录中并解压 tar -xzvf tar -xzvf apache-maven-3.9.6-bin.tar…

【大数据存储】实验3 HBase的安装和基本操作

实验3 HBase的安装和基本操作 实验环境&#xff1a; Ubuntu 22.04.3 Jdk 1.8.0_341 Hadoop 3.2.3 Hbase 2.4.17 一、安装HBase HBase伪分布式安装的配置 1. 配置hbase-env.sh文件 3. 启动运行HBase 4. 停止运行HBase HBase常用的Shell命令 打开hbase 在HBase中创建…

2024年150道高频Java面试题(十五)

29. 请解释 Java 集合框架的基本结构。 Java 集合框架&#xff08;Java Collections Framework&#xff0c;JCF&#xff09;提供了一个统一的架构&#xff0c;用于存储和操作集合数据。它包含接口、实现这些接口的类以及操作集合的工具类。以下是 Java 集合框架的基本结构&…

python实现UDP客户端

import socket # 设置服务器的IP地址和端口 SERVER_IP 127.0.0.1 SERVER_PORT 12345 # 创建一个socket对象 client_socket socket.socket(socket.AF_INET, socket.SOCK_DGRAM) # 准备要发送的数据 message_to_send "Hello, UDP Server!" # 发送数据到服务…

day02-SpringCloud02(Nacos、Feign、Gateway)

1.Nacos 配置管理 Nacos 除了可以做注册中心&#xff0c;同样可以做配置管理来使用。 1.1.统一配置管理 当微服务部署的实例越来越多&#xff0c;达到数十、数百时&#xff0c;逐个修改微服务配置就会让人抓狂&#xff0c;而且很容易出错。我们需要一种统一配置管理方案&#x…

005 高并发内存池_CentralCache设计

​&#x1f308;个人主页&#xff1a;Fan_558 &#x1f525; 系列专栏&#xff1a;高并发内存池 &#x1f339;关注我&#x1f4aa;&#x1f3fb;带你学更多知识 文章目录 前言本文重点一、构建CentralCache结构二、运用慢开始反馈调节算法三、完成向CentralCache中心缓存申请四…

javaScript中微任务宏任务详解

在 JavaScript 中&#xff0c;任务分为两种类型&#xff1a;微任务&#xff08;Microtask&#xff09;和宏任务&#xff08;Macrotask&#xff09;。它们的执行顺序以及在事件循环&#xff08;Event Loop&#xff09;中的位置不同。 微任务&#xff08;Microtask&#xff09;&…

【JavaScript】函数 ③ ( 形参 与 实参 匹配问题 | 实参个数 = 形参个数 | 实参个数 > 形参个数 | 实参个数 < 形参个数 )

文章目录 一、JavaScript 函数 形参 与 实参 匹配问题1、函数形参与实参不匹配问题2、形参与实参个数匹配3、实参个数 > 形参个数4、实参个数 < 形参个数5、完整代码示例 一、JavaScript 函数 形参 与 实参 匹配问题 1、函数形参与实参不匹配问题 在 其它语言 中 , 如 Ja…

华为机试打卡 HJ102 字符统计

要机试了&#xff0c;华孝子求捞&#xff0c;功德 描述 输入一个只包含小写英文字母和数字的字符串&#xff0c;按照不同字符统计个数由多到少输出统计结果&#xff0c;如果统计的个数相同&#xff0c;则按照ASCII码由小到大排序输出。 数据范围&#xff1a;字符串长度满足 …

开发人员小张出场

小张一年前入职&#xff0c;当时毕业已经一年了&#xff0c;一年换了4份工作。最少的才呆了一周。 小张的简历很正规&#xff0c;彩色打印&#xff0c;整整5页。技能篇写的很全&#xff0c;基本上市面上的技术都写到了&#xff0c;都是精通。面试的时候&#xff0c;表现也很好&…

C语言 | Leetcode C语言题解之第6题Z字形变换

题目&#xff1a; 题解&#xff1a; char * convert(char * s, int numRows){int n strlen(s), r numRows;if (r 1 || r > n) {return s;}int t r * 2 - 2;char * ans (char *)malloc(sizeof(char) * (n 1));int pos 0;for (int i 0; i < r; i) { // 枚举矩阵的…

docker搭建DDClient

DDClient 是一个用 Perl 编写的开源客户端&#xff0c;主要用于通过动态 DNS 服务更新动态域名。它能够自动检测公网 IP 地址的变化&#xff0c;并将新的 IP 地址更新到指定的 DNS 服务商&#xff0c;以保持域名与当前 IP 地址的同步。这对于使用动态 IP 地址的用户来说非常有用…

上位机图像处理和嵌入式模块部署(qmacvisual之n点标定)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 工业场景中&#xff0c;很多时候图像是用来做测量的。虽然我们很希望载台是平的&#xff0c;摄像头是正对着拍摄物体的&#xff0c;但是运行时间长…

达梦数据库用户与权限管理

达梦数据库用户与权限管理 用户管理口令策略管理用户资源限制 权限管理一般权限特殊权限 角色管理 用户管理 达梦数据库安装后创建的内置用户&#xff1a; SYS&#xff1a;内置用户&#xff0c;不允许登录。该用户下有常用的数据字典&#xff1b;SYSDBA&#xff1a;系统管理员…

【华为OD机试】启动多任务排序(拓扑排序算法—JavaPythonC++JS实现)

本文收录于专栏:算法之翼 本专栏所有题目均包含优质解题思路,高质量解题代码(Java&Python&C++&JS分别实现),详细代码讲解,助你深入学习,深度掌握! 文章目录 一. 题目二.解题思路三.题解代码Python题解代码JAVA题解代码C/C++题解代码JS题解代码四.代码讲解(Ja…

AssetBundle在移动设备上丢失

1&#xff09;AssetBundle在移动设备上丢失 2&#xff09;Unity云渲染插件RenderStreaming&#xff0c;如何实现多用户分别有独立的操作 3&#xff09;如何在圆柱体类型的地图中编程玩家的输入 4&#xff09;Mixamo动画的根运动问题 这是第380篇UWA技术知识分享的推送&#xff…

leetcode热题100.前k个高频元素

作者&#xff1a;晓宜 &#x1f308;&#x1f308;&#x1f308; 个人简介&#xff1a;互联网大厂Java准入职&#xff0c;阿里云专家博主&#xff0c;csdn后端优质创作者&#xff0c;算法爱好者 ❤️❤️❤️ 你的关注是我前进的动力&#x1f60a; Problem: 347. 前 K 个高频元…

高效率二极管选型参数,结构原理,工艺与注意问题总结

🏡《总目录》 目录 1,概述2,工作原理2.1,正向偏置2.2,反向偏置3,结构特点3.1,材料选择3.2,结构设计3.3,掺杂工艺4,工艺流程4.1,材料准备4.2,设备准备4.3,环境准备4.4

离散化、贪心、双指针、二分、倍增、构造、位运算

八、离散化 1、离散化简介 把无限空间中有限的个体映射到有限的空间中去,以此提高算法的时空效率。离散化是一种将数组的值域压缩,从而更加关注元素的大小关系的算法。当原数组中的数字很大、负数、小数时(大多数情况下是数字很大),难以将“元素值”表示为”数组下标“,一…

为什么mac文件拖拽不了 mac文件拖不进硬盘里 macbookpro文件无法拖进移动硬盘 Tuxera NTFS for Mac 2023绿色

如果你是一位Mac用户&#xff0c;你可能会遇到这样的问题&#xff1a;你想把Mac上的文件拖拽到其他位置&#xff0c;比如桌面、文件夹或者外接硬盘&#xff0c;但是却发现无法操作&#xff0c;这是为什么呢&#xff1f;这篇文章将为你解答为什么mac文件拖拽不了&#xff0c;以及…