`

Range Sum Query - Immutable

阅读更多
Given an integer array nums, find the sum of the elements between indices i and j (i ≤ j), inclusive.

Example:
Given nums = [-2, 0, 3, -5, 2, -1]

sumRange(0, 2) -> 1
sumRange(2, 5) -> -1
sumRange(0, 5) -> -3

Note:
You may assume that the array does not change.
There are many calls to sumRange function.

题目的意思是给定一个数组,如果调用sumRange(i, j) 就返回(i, j)之间 所有元素的和,题目Note中提到sumRange会被调用好多次,这句话的意思就是不希望我们每次都计算从i到j之间的和,这样会浪费很多时间。我们就需要先计算好每个区间的和,然后在调用sumRange后直接返回结果,不需要每次都计算。代码如下:
public class NumArray {
    int[] sumArray;
    public NumArray(int[] nums) {
        sumArray = new int[nums.length + 1];
        for(int i = 1; i <= nums.length; i++) {
            sumArray[i] = nums[i - 1] + sumArray[i - 1];
        }
    }

    public int sumRange(int i, int j) {
        return sumArray[j + 1] - sumArray[i];
    }
}


// Your NumArray object will be instantiated and called as such:
// NumArray numArray = new NumArray(nums);
// numArray.sumRange(0, 1);
// numArray.sumRange(1, 2);
分享到:
评论

相关推荐

    java-leetcode题解之Range Sum Query - Immutable.java

    java java_leetcode题解之Range Sum Query - Immutable.java

    dot-prop-immutable, 点prop的不可变版本,带有一些扩展名.zip

    dot-prop-immutable, 点prop的不可变版本,带有一些扩展名 dot-prop-immutable 点prop的不可变版本,带有一些扩展名。npm install dot-prop-immutable这个模块的动机是在不改变普通JavaScript对象的现有状态的情况

    前端开源库-redux-immutable

    了解了redux-immutable的基本用法后,我们来看看压缩包中的文件`redux-immutable-master`。这通常代表了项目的源代码仓库,包含项目的根目录、README文件、源码、测试文件、配置文件等。开发者可以通过查看源码来...

    前端开源库-chai-immutable

    在`chai-immutable-master`压缩包中,包含的是`chai-immutable`项目的源代码。通常,这样的项目会包含以下组成部分: 1. **源码**:主要位于`src`目录下,这是实现`chai-immutable`核心功能的JavaScript代码。 2. *...

    前端开源库-typed-immutable

    **前端开源库-typed-immutable** 在前端开发中,数据管理是至关重要的,尤其是在大型应用中,保持数据的一致性和可预测性对于代码的维护和性能优化有着决定性的作用。`typed-immutable`是一个专门为JavaScript设计...

    前端项目-seamless-immutable.zip

    `seamless-immutable` 是一个专门针对JavaScript设计的不可变数据结构库,它为开发者提供了与原生JavaScript数组和对象兼容的接口,同时确保了数据一旦创建就无法被修改。这个库的核心理念是为了帮助开发者实现更...

    go-immutable-radix, 在Golang中,一个不可变的基数树实现.zip

    go-immutable-radix, 在Golang中,一个不可变的基数树实现 go-immutable-radix 提供实现不可变 radix的iradix 包。 包只提供单个 Tree 实现,针对稀疏节点优化。作为一个基数树,它提供以下内容:O(k) 操作。在许多...

    前端开源库-immutable-instance-id

    "前端开源库-immutable-instance-id"就是这样一个工具,它的主要功能是为每个进程实例生成一个唯一的、不可变的ID。这个ID在进程运行期间保持不变,确保了在多线程或者分布式环境中的数据追踪和标识的独特性。 不可...

    前端开源库-immutable-core

    **前端开源库-immutable-core详解** 在前端开发领域,优化性能和提高代码可维护性是开发者不断追求的目标。为此,各种工具和库应运而生,其中“immutable-core”是一个非常重要的概念,它代表着一种不可变数据处理...

    ToDo-react-redux-immutable, ToDo应用显示使用反应,重现和ImmutableJS的最佳实践.zip

    ToDo-react-redux-immutable, ToDo应用显示使用反应,重现和ImmutableJS的最佳实践 技巧,技巧和最佳实践,使用反应,重现和 ImmutableJS请检查文章解释逻辑&gt; ...ToDo应用演示如何使用Red

    LeetCode:Leetcode-解决方案

    Range Sum Query - Immutable [303]7. Counting Bits [338]8. Palindromic Substrings [647]9. Maximum Length of Pair Chain [646]10. Integer Break [343]11. Count Numbers with Unique Digits [357]12. 2-Key

    CKS - Practise - Immutable.docx

    CKS - Practise Immutable Resource

    21-C-ImmutableObject-Code.zip

    在编程领域,不可变对象(Immutable Object)是一种重要的设计模式,尤其在多线程和并发环境中,它提供了安全性和性能优化。在这个初学者教程中,我们将深入探讨C#中的不可变对象,包括“内部不变性”和“观察不变性...

    seamless-immutable-diff

    给定两个对象,获取它们之间的Seamless-immutable-diff 安装 如果尚未下载node,请从下载并安装。 npm install seamless-immutable-diff --save 用法 import diff from 'seamless-immutable-diff' ; import ...

    kotlinx.collections.immutable,Kotlin的不可变集合原型.zip

    在Kotlin编程语言中,`kotlinx.collections.immutable`是一个重要的库,它提供了不可变集合的实现。不可变集合是一旦创建后就不能修改的集合,这种数据结构在多线程环境、函数式编程和构建安全的数据模型时非常有用...

    前端开源库-immutable-ai

    **前端开源库 Immutable.js** Immutable.js 是一个 JavaScript 库,由 Facebook 的 React 团队开发并维护,它为开发者提供了一种在前端开发中高效处理数据的方法。该库的核心概念是不可变数据,即一旦创建,数据就...

    3、动态规划必练题(含解法).pdf

    16. **Range Sum Query 2D - Immutable** (二维不可变范围求和) 类似于一维,但在二维数组上进行范围求和。可以使用二维前缀和。 17. **Longest Increasing Subsequence** (最长递增子序列) 寻找数组中最长的严格...

    article-json-immutable-methods

    article-json-immutable-methods 文章json的不可变方法安装如果尚未下载node,请从下载并安装。 npm install article-json-immutable-methods --save测验npm installnpm test依存关系 :通常可变数组方法的不可变...

    前端开源库-immutable-require-valid-optional-object

    本文将深入探讨“immutable-require-valid-optional-object”这一特定的开源库,它专注于处理不可变对象,并确保传入的对象参数是有效的。 “immutable-require-valid-optional-object”库的核心理念是维护数据的不...

Global site tag (gtag.js) - Google Analytics