303. Range Sum Query - Immutable

2017-04-27  本文已影响6人  Double_E

https://leetcode.com/problems/range-sum-query-immutable/#/description

Paste_Image.png

方法1: 直接求和

class NumArray(object):

    def __init__(self, nums):
        """
        :type nums: List[int]
        """
        self.nums = nums
        

    def sumRange(self, i, j):
        """
        :type i: int
        :type j: int
        :rtype: int
        """
        s = 0
        for k in range(i, j+1):
            s += self.nums[k]
        return s

方法2: 空间换时间

class NumArray(object):

    def __init__(self, nums):
        """
        :type nums: List[int]
        """
        self.cusum = [0]
        for num in nums:
            self.cusum += [self.cusum[-1] + num]
        

    def sumRange(self, i, j):
        """
        :type i: int
        :type j: int
        :rtype: int
        """
        return self.cusum[j + 1] - self.cusum[i]
上一篇 下一篇

猜你喜欢

热点阅读