日拱一卒,月进一步(10)

简介: 303. 区域和检索 - 数组不可变 - 力扣(LeetCode)动态规划~

303. 区域和检索 - 数组不可变 - 力扣(LeetCode)

动态规划~

前缀和、

最朴素的思想是存储数组nums的值,每次调用sumRange时,通过循环的方法计算数组nums从下标i到下标j的元素和,需要计算j-i+1个元素的和。由于每次检索的时间和检索的下标范围有关,因此检索的时间复杂度较高,如果检索的次数过多,会超出时间限制。


我们应该尽量降低sumRange的时间复杂度,最理想的时间复杂度是O(1)。

218167e9642594e7f2e4b5aed2b2a74f_f2de7617dd524282ad258d64ac788b1b.png

因此,要计算sumRange(i,j),则需要计算数组nums在下标i-1和j的前缀和,并计算两个前缀和的差。如果可以在初始化时就计算nums在每个下标的前缀和。即可满足调用sumRange的时间复杂度都是O(1)。


具体实现方面,假设数组的长度nums等于n,创建长度为n+1的前缀和数组nums,sums[i+1]=sums[i]+nums[i],则sums[i]表示数组从0到下标i-1的前缀和。


将前缀和数组 sum 的长度设为 n+1的目的是为了方便计算 sumRange(i,j),不需要对 i=0的情况特殊处理。此时有:

8c4eab9c58563be4182edf8f6216a13c_f093d787649c44d7bbfb3a10064d3365.png

typedef struct {
    int* sums;
} NumArray;
 
 
NumArray* numArrayCreate(int* nums, int numsSize) {
    NumArray* ret=malloc(sizeof(NumArray));
    ret->sums=malloc(sizeof(int)*(numsSize+1));
    ret->sums[0]=0;
    for(int i=0;i<numsSize;i++)
    {
        ret->sums[i+1]=ret->sums[i]+nums[i];
    }
    return ret;
    }
 
int numArraySumRange(NumArray* obj, int i, int j) {
    return obj->sums[j+1]-obj->sums[i];
}
 
void numArrayFree(NumArray* obj) {
    free(obj->sums);
}
 
/**
 * Your NumArray struct will be instantiated and called as such:
 * NumArray* obj = numArrayCreate(nums, numsSize);
 * int param_1 = numArraySumRange(obj, left, right);
 
 * numArrayFree(obj);
*/


8c4eab9c58563be4182edf8f6216a13c_f093d787649c44d7bbfb3a10064d3365.png

相关文章
|
存储 运维 数据处理
AIGC浪潮对数据中心基础设施发展的影响
【1月更文挑战第19天】AIGC浪潮对数据中心基础设施发展的影响
453 1
AIGC浪潮对数据中心基础设施发展的影响
Vue3接口数据报错TypeError: target must be an object
Vue3接口数据报错TypeError: target must be an object
1715 0
ThreeJs控制模型的隐藏与显示
这篇文章讲解了如何在Three.js中通过代码控制3D模型的显示与隐藏状态。
263 3
ThreeJs控制模型的隐藏与显示
|
小程序 JavaScript
微信小程序之input组件及其获取用户输入信息
微信小程序之input组件及其获取用户输入信息
347 2
|
存储 NoSQL 测试技术
go最佳实践:如何舒适地编码
go最佳实践:如何舒适地编码
|
数据可视化 搜索推荐 数据挖掘
基于Python flask 的数据可视化平台,可定制,可连接数据库
本文介绍了一个基于Python Flask框架开发的可定制数据可视化平台,该平台支持多种数据库连接,并提供丰富的图表类型和个性化设置,以实现交互式数据分析和展示。
387 0
基于Python flask 的数据可视化平台,可定制,可连接数据库
|
Java 调度 开发者
如何在Java中实现任务调度
如何在Java中实现任务调度
flutter 引用图片资源遇到的问题
flutter 引用图片资源遇到的问题
314 1
|
算法 编译器 数据处理
嵌入式中的 C 语言
嵌入式中的 C 语言 嵌入式C语言和普通C语言在语法上几乎没有差别其主要差别在于普通C语言的运行环境是OS之上,有很多的标准库函数支撑调用,分配的内存是电脑的内存,其处理器就是电脑的CPU;而在嵌入式环境中,会涉及到底层的硬件,而硬件本身是没有标准库可以调用的,因而就需要开发者使用C语言编程调试硬件,使其可以工作,对于开发某一款芯片,有针对的编译器(或者交叉编译环境),可以分配的内存则是芯片的RAM、Flash,处理器则是芯片自身带的MCU,例如ARM、DSP等。
415 0
嵌入式中的 C 语言
|
弹性计算 安全 网络安全
基于阿里云云平台快速实现网络入侵检测 (IDS) 及网络安全监视 (NSM)
数据包捕获是一个重要组件,可以实施网络入侵检测系统 (IDS) 并执行网络安全监视 (NSM)。 我们可以借助开源 IDS 工具来处理数据包捕获,并检查潜在网络入侵和恶意活动的签名。 使用网络观察程序提供的数据包捕获,可以分析网络中是否存在任何有害入侵或漏洞,Suricata 就是这样的一种开源工具,它是一个 IDS 引擎,可使用规则集来监视网络流量,每当出现可疑事件时,它会触发警报。 Suricata 提供多线程引擎,意味着它能够以更高的速度和效率执行网络流量分析,在本文中将会介绍到如何在 ECS 中使用Suricata来对网络进行入侵检测,同时并根据Suricata中给定的威胁规则匹配的
2151 0
基于阿里云云平台快速实现网络入侵检测 (IDS) 及网络安全监视 (NSM)