【前缀和】303. 区域和检索 - 数组不可变

简介: 【前缀和】303. 区域和检索 - 数组不可变

📍前言

🕺作者: 迷茫的启明星


学习路线

C语言从0到1

C++初阶

数据结构从0到1

😘欢迎关注:👍点赞🙌收藏✍️留言


🏇码字不易,你的👍点赞🙌收藏❤️关注对我真的很重要,有问题可在评论区提出,感谢阅读!!!


持续更新中~


【前缀和】303. 区域和检索 - 数组不可变

题目概述

给定一个整数数组 nums,实现一个类 NumArray,用于处理以下类型的多个查询:计算索引 left 和 right(包含 left 和 right)之间的 nums 元素的和。其中 left <= right。


题解思路

这个问题可以通过前缀和数组来求解。前缀和数组是一种数据结构,用于在 O(1) 时间复杂度内求解给定区间内的元素之和。前缀和数组的基本思想是将原数组中的元素之和存储在一个新的数组中,使得可以通过简单的数组访问操作来获取区间和。


NumArray 类的实现

首先,定义一个 NumArray 类,包含一个构造函数和一个 sumRange 方法。构造函数接受一个整数数组 nums 作为参数,用于初始化前缀和数组。sumRange 方法接受两个整数 left 和 right 作为参数,用于计算给定区间内的元素和。

class NumArray {
public:
    vector<int> sums;
    NumArray(vector<int>& nums) {
        int n = nums.size();
        sums.resize(n + 1);
        for (int i = 0; i < n; i++) {
            sums[i + 1] = sums[i] + nums[i];
        }
    }
    int sumRange(int left, int right) {
        return sums[right + 1] - sums[left];
    }
};



前缀和数组的计算过程

在构造函数中,我们首先计算原数组的长度 n,并将前缀和数组的大小设置为 n + 1。然后,我们遍历原数组,将每个元素累加到前缀和数组中。注意,前缀和数组的第 i 个元素表示原数组的前 i 个元素之和。


求解区间和

sumRange 方法接受两个整数 left 和 right,用于计算给定区间内的元素和。我们可以通过计算前缀和数组中索引 right + 1 和 left 对应的元素之差来求解区间和。这样,我们可以在 O(1) 时间复杂度内完成区间和的计算。


总结

通过使用前缀和数组,我们可以在 O(1) 时间复杂度内求解给定区间内的元素和。这种数据结构在解决区间查询问题时非常有效。在实际应用中,前缀和数组还可以扩展到多维数组,用于求解更高维度的区间问题。


相关文章
|
6月前
|
算法 前端开发
100224. 分割数组
100224. 分割数组
40 0
|
5月前
|
存储 人工智能 BI
小苯的九宫格,小苯的好数组(排序),小苯的数字合并(字典树,前缀和)
小苯的九宫格,小苯的好数组(排序),小苯的数字合并(字典树,前缀和)
42 3
|
6月前
DAY-2 | 哈希表、指针与区间划分:字符种数统计问题
```markdown ## 题干 [牛客网链接](https://www.nowcoder.com/practice/eb94f6a5b2ba49c6ac72d40b5ce95f50) ## 题解 1. **查表法(哈希表)**:利用数组标记出现过的 ASCII 值小于127的字符,首次出现计数,重复则忽略。 2. **指针与区间划分(回头法)**:遍历字符串,对每个字符检查其前所有字符是否重复,重复则不计数。 ## 方法总结 - 哈希表在去重问题中非常实用,可多做相关练习。 - 使用`continue`时注意避免死循环,确保循环变量会改变。 - 多回顾此类问题以巩固理解。 ```
41 2
|
6月前
|
数据挖掘 计算机视觉 Python
Python实现对规整的二维列表中每个子列表对应的值求和
Python实现对规整的二维列表中每个子列表对应的值求和
55 0
|
6月前
|
人工智能 自然语言处理 算法
【动态规划】【字符串】【前缀和】1639通过给定词典构造目标字符串的方案数
【动态规划】【字符串】【前缀和】1639通过给定词典构造目标字符串的方案数
|
6月前
|
索引 Python
leetcode-303:区域和检索 - 数组不可变
leetcode-303:区域和检索 - 数组不可变
30 0
|
6月前
|
C++ 索引 Python
区域和检索 - 数组不可变(C++)
区域和检索 - 数组不可变(C++)
42 0
|
6月前
|
索引 Python
leetcode-307:区域和检索 - 数组可修改
leetcode-307:区域和检索 - 数组可修改
35 0
|
6月前
|
JavaScript SoC
leetcode-304:二维区域和检索 - 矩阵不可变
leetcode-304:二维区域和检索 - 矩阵不可变
58 0
|
JavaScript Python
从列表中或数组中随机抽取固定数量的元素组成新的数组或列表
从列表中或数组中随机抽取固定数量的元素组成新的数组或列表
62 0