[link](https://leetcode.com/problems/range-sum-query-immutable/) --- Given an integer array nums, handle multiple queries of the following type: Calculate the sum of the elements of nums between indices left and right inclusive where left <= right. Implement the NumArray class: NumArray(int[] nums) Initializes the object with the integer array nums. int sumRange(int left, int right) Returns the sum of the elements of nums between indices left and right inclusive (i.e. nums[left] + nums[left + 1] + ... + nums[right]). #### Example 1: ``` Input ["NumArray", "sumRange", "sumRange", "sumRange"] [[[-2, 0, 3, -5, 2, -1]], [0, 2], [2, 5], [0, 5]] Output [null, 1, -1, -3] Explanation NumArray numArray = new NumArray([-2, 0, 3, -5, 2, -1]); numArray.sumRange(0, 2); // return (-2) + 0 + 3 = 1 numArray.sumRange(2, 5); // return 3 + (-5) + 2 + (-1) = -1 numArray.sumRange(0, 5); // return (-2) + 0 + 3 + (-5) + 2 + (-1) = -3 ``` #### Constraints: - 1 <= nums.length <= 104 - -105 <= nums[i] <= 105 - 0 <= left <= right < nums.length - At most 104 calls will be made to sumRange. --- The __init__ method initializes the NumArray object with a list of integers nums. It calculates and stores the prefix sum of the input list in the prefixSum list. The sumRange method takes two parameters left and right and returns the sum of the elements in the range from index left to index right (both inclusive). It does this efficiently using prefix sums by subtracting the prefix sum of left - 1 (if left is greater than 0) from the prefix sum of right. #### Solution 1 ```python= class NumArray: def __init__(self, nums: List[int]): self.prefixSum = [] total = 0 for n in nums: total += n self.prefixSum.append(total) def sumRange(self, left: int, right: int) -> int: preRight = self.prefixSum[right] preLeft = self.prefixSum[left - 1] if left > 0 else 0 return (preRight - preLeft) ``` O(T): O(n) O(S): O(n)