python题解LeetCode303区域和检索示例详解

 更新时间:2022年12月30日 14:45:05   作者:刘09k11  
这篇文章主要为大家介绍了python题解LeetCode303区域和检索示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

题目描述

原题链接 :

303. 区域和检索

给定一个整数数组  nums,处理以下类型的多个查询:

  • 计算索引 left 和 right (包含 left 和 right)之间的 nums 元素的 和 ,其中 left <= right

实现 NumArray 类:

  • NumArray(int[] nums) 使用数组 nums 初始化对象
  • int sumRange(int i, int j) 返回数组 nums 中索引 left 和 right 之间的元素的 总和 ,包含 left 和 right 两点(也就是 nums[left] + nums[left + 1] + ... + nums[right] )  

示例 1:

输入:
["NumArray", "sumRange", "sumRange", "sumRange"]
[[[-2, 0, 3, -5, 2, -1]], [0, 2], [2, 5], [0, 5]]
输出:
[null, 1, -1, -3]
解释:
NumArray numArray = new NumArray([-2, 0, 3, -5, 2, -1]);
numArray.sumRange(0, 2); // return 1 ((-2) + 0 + 3)
numArray.sumRange(2, 5); // return -1 (3 + (-5) + 2 + (-1)) 
numArray.sumRange(0, 5); // return -3 ((-2) + 0 + 3 + (-5) + 2 + (-1))

提示:

1 <= nums.length <= 10^4

-10^5 <= nums[i] <= 10^5

0 <= i <= j < nums.length

最多调用 10^4 次 sumRange 方法

思路分析

如果sumRange方法只调用一次的话,很简单,使用暴力求解的方式,时间复杂度为O(n),如果sumRange方法被多次调用的话,那么便不能使用暴力求解的方式,因为时间复杂度会达到O(n^2),使用动态规划的方式进行求解。

建立一个数组dp, 用于存储前面所有数到当前数字的和,例如数组为[1, 2, 3, 4],则dp = [1, 3, 6, 10];

在sumRange函数中定义求解方式。以[1, 2, 3, 4]数组为例,如果[I, j] = [0, 2], 则要求的结果为res = 6 = 1 + 2 + 3,而对应于dp中的数,res = dp[2] – 0,若[I, j ] = [1, 3], 则res = 9 = 2 + 3 + 4 = dp[3] – dp[0] = 10 – 1 = 9, 因此可以由此推断出求解公式: res = dp[j], if i =0 ; res = dp[j] - dp[i-1], if i > 0

AC 代码

class NumArray:
    def __init__(self, nums: List[int]):
        self.dp = []
        if len(nums) == 0:
            return
        self.dp.append(nums[0])
        for i in range(1, len(nums)):
            self.dp.append(self.dp[i-1] + nums[i])
    def sumRange(self, i: int, j: int) -> int:
        if i == 0:
            return self.dp[j] 
        else:
            return self.dp[j] - self.dp[i - 1]
# Your NumArray object will be instantiated and called as such:
# obj = NumArray(nums)
# param_1 = obj.sumRange(i,j)

以上就是python题解LeetCode303区域和检索示例详解的详细内容,更多关于python题解区域检索的资料请关注脚本之家其它相关文章!

相关文章

  • python数据预处理 :数据抽样解析

    python数据预处理 :数据抽样解析

    这篇文章主要介绍了python数据预处理 :数据抽样解析,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02
  • pandas中pd.groupby()的用法详解

    pandas中pd.groupby()的用法详解

    本文主要介绍了pandas中pd.groupby()的用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧<BR>
    2022-06-06
  • python3 图片 4通道转成3通道 1通道转成3通道 图片压缩实例

    python3 图片 4通道转成3通道 1通道转成3通道 图片压缩实例

    今天小编就为大家分享一篇python3 图片 4通道转成3通道 1通道转成3通道 图片压缩实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • Python数据结构与算法中的队列详解(1)

    Python数据结构与算法中的队列详解(1)

    这篇文章主要为大家详细介绍了Python的队列,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • Django 路由控制的实现代码

    Django 路由控制的实现代码

    这篇文章主要介绍了Django 路由控制的实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • python学习之使用Matplotlib画实时的动态折线图的示例代码

    python学习之使用Matplotlib画实时的动态折线图的示例代码

    这篇文章主要介绍了python学习之使用Matplotlib画实时的动态折线图的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • Django与JS交互的示例代码

    Django与JS交互的示例代码

    本篇文章主要介绍了Django与JS交互的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • Python面向对象程序设计构造函数和析构函数用法分析

    Python面向对象程序设计构造函数和析构函数用法分析

    这篇文章主要介绍了Python面向对象程序设计构造函数和析构函数用法,结合具体实例形式分析了Python面向对象程序设计中构造函数与析构函数的概念、原理、功能及相关使用技巧,需要的朋友可以参考下
    2019-04-04
  • Python urllib 入门使用详细教程

    Python urllib 入门使用详细教程

    urllib 库,它是 Python 内置的 HTTP 请求库,不需要额外安装即可使用,这篇文章主要介绍了Python urllib 入门使用,需要的朋友可以参考下
    2022-11-11
  • 使用Python的Twisted框架实现一个简单的服务器

    使用Python的Twisted框架实现一个简单的服务器

    这篇文章主要介绍了使用Python的Twisted框架实现一个简单的服务器,翻译自Twisted的文档,需要的朋友可以参考下
    2015-04-04

最新评论