Range Sum Query - Mutable

Problem: Range Sum Query - Mutable

The general solution is binary-indexed tree. The link refers to a detailed tutorial. Its basic idea is to store partial range sum at an array-implemented tree.

Code in Python:

class NumArray(object):
    def __init__(self, nums):
        """
        initialize your data structure here.
        :type nums: List[int]
        """
        self.length = len(nums) + 1
        self.nums = nums
        self.tree = [0] * self.length
        for i in xrange(1, self.length):
            self.tree[i] = self.sumBefore(i-1) - self.sumBefore(i-(i&(-i))) + self.nums[i-1]

    def sumBefore(self, i):
        return 0 if i == 0 else self.tree[i] + self.sumBefore(i-(i&(-i)))


    def update(self, i, val):
        """
        :type i: int
        :type val: int
        :rtype: int
        """
        diff = val - self.nums[i]
        self.nums[i] = val
        i += 1
        while i < self.length:
            self.tree[i] += diff
            i += (i&(-i))


    def sumRange(self, i, j):
        """
        sum of elements nums[i..j], inclusive.
        :type i: int
        :type j: int
        :rtype: int
        """
        return self.sumBefore(j+1) - self.sumBefore(i)

results matching ""

    No results matching ""