当前位置: 首页 > news >正文

力扣303 区域和检索 - 数组不可变

文章目录

  • 题目介绍
  • 题解

题目介绍

在这里插入图片描述

题解

不用管第一个null,从第二个开始看就可以
法一:暴力解法

class NumArray {private int[] nums;public NumArray(int[] nums) {this.nums = nums;}public int sumRange(int left, int right) {int res = 0;for (int i = left; i <= right; i++) {res += nums[i];}return res;}
}

法二:前缀和
前缀和方法:一种重要的预处理技术,用于快速计算数组中任意区间的元素之和。 它的核心思想是先计算数组中每个位置到起始位置的累积和,然后通过简单的加减运算,就可以快速得到任意区间的和。

为方便描述,把nums记作a。对于数组a,定义它的前缀和:
在这里插入图片描述在这里插入图片描述s[i]代表a[0]+…a[i-1]

定义s[0]的目的是为了解决求当left = 0 的情况。是为了照顾到a[0]=s[1]-s[0]

代码如下:

class NumArray {private int[] s;public NumArray(int[] nums) {s = new int[nums.length + 1];  // 默认初始化为全零for (int i = 0; i < nums.length; i++) {s[i + 1] = s[i] + nums[i];}}public int sumRange(int left, int right) {return s[right + 1] - s[left];}
}

相关文章:

  • ubuntu 20.04 运行和编译LOAM_Velodyne
  • EtherCAT通讯框架
  • 导轨固定螺栓的扭矩标准是多少?
  • RAC共享存储扩容
  • win11下,启动springboot时,提示端口被占用的处理方式
  • RAG策略
  • Python读取和处理TIFF数据教程 (由简入深)
  • NumPy 2.x 完全指南【十一】N 维数组对象(ndarray)
  • 庐山派 HDMI Python 图像开发 K230图像传输方案
  • 在资源受限环境下,移动端如何实现流畅动画?如何在内存、CPU、GPU、网络等多种限制条件下,依然保持动画高帧率、低延迟、不卡顿?
  • 自定义协议与序列化
  • 大型商用货运无人机强势入局2025深圳eVTOL展
  • 【硬核数学】2. AI如何“学习”?微积分揭秘模型优化的奥秘《从零构建机器学习、深度学习到LLM的数学认知》
  • 亚远景-ASPICE与ISO 21434在汽车电子系统开发中的应用案例
  • 微服务项目->在线oj系统(Java版 - 5)
  • 机器学习第十六讲:K-means → 自动把超市顾客分成不同消费群体
  • Java—— File详解
  • VTK|箱体切割器
  • 【git进阶】git rebase(变基)
  • 前端子项目打包集成主项目实战指南
  • 在“三只手”上跳舞:公共政策的科学与艺术——读《市场、国家和民众:公共政策经济学》
  • 英伟达推出新技术加速AI芯片连接,期望构建互联互通生态
  • 北美票房|华纳又赢了,《死神来了6》开画远超预期
  • 上海迪士尼蜘蛛侠主题园区正式动工,毗邻“疯狂动物城”
  • 国际博物馆日|航海博物馆:穿梭于海洋神话与造船工艺间
  • “马上涨价”再到“吞下关税”,美政策让沃尔玛“输两次”