LeetCode No.303 Range Sum Query - Immutable | #Dynamic-programming #Array

Q:

Given an integer array nums, find the sum of the elements between indices i and j (ij), inclusive.
Example:
Given nums = [-2, 0, 3, -5, 2, -1] sumRange(0, 2) -> 1 sumRange(2, 5) -> -1 sumRange(0, 5) -> -3
Note:
You may assume that the array does not change. There are many calls to sumRange function.

public NumArray(int[] nums) {
}
public int sumRange(int i, int j) {
}
       // Your NumArray object will be instantiated and called as such:
       // NumArray numArray = new NumArray(nums);
       // numArray.sumRange(0, 1);
       // numArray.sumRange(1, 2);

}

注:求的是range内所有数的总和。

#A:

这个BF比较直观,但时间复杂度不是最优。因为有个for loop,所以时间复杂度是O(n)。

Q:为什么这个会Time Limit Exceeded(超时)?
如果array里面数字少,算range sum其实还好,效率应该是不错的吧!?但是如果数字大了,最极限的情况,比如 `int[] test = new int[1000000];`那要是我们求`.sumRange(3,999999)`,loop trace基本无限趋近于O(n)了。所以,放大测试,就会发现问题。

private int[] data;

public NumArray(int[] nums) {
data = nums; //data is reference
}

public int sumRange(int i, int j) {
int sum = 0;
for (int k = i; k <= j; k++) { //这里有个for loop, 所以时间复杂度:O(n)
sum += data[k];
}
return sum;
}


这个最优,时间复杂度O(1),空间复杂度O(n)

public class NumArray {
int[] nums;

public NumArray(int[] nums) {   //pre-caculation
    this.nums = nums;

    for(int i = 1; i < nums.length; i++)
        nums[i] += nums[i - 1];
}

public int sumRange(int i, int j) {
    if(i == 0)          //这个if判断不能省略
        return nums[j];
    else
       return nums[j] - nums[i - 1];
}

}

思路同上,但加入dummy 0,省去if判断

private int[] sum;

public NumArray(int[] nums) {
sum = new int[nums.length + 1];
for (int i = 0; i < nums.length; i++) {
sum[i + 1] = sum[i] + nums[i];
}
}

public int sumRange(int i, int j) {
return sum[j + 1] - sum[i];
}


这个处理起来有点儿绕,要多declaration一个array。另外毕竟length不一样,要加1。
优点是不需要if判断了。原作者是这么解释的:

>Notice in the code above we inserted a dummy 0 as the first element in the *sum* array. This trick saves us from an extra conditional check in *sumRange*function.
**Complexity analysis** :Time complexity : O(1),Space complexity : O(n)
O(n) time pre-computation. Since the cumulative sum is cached, each *sumRange* query can be calculated in O(1).

----
LeetCode editorial solution approach #2

private Map<Pair<Integer, Integer>, Integer> map = new HashMap<>();

public NumArray(int[] nums) {
int sum = 0;

for (int i = 0; i < nums.length; i++) {
    for (int j = i; j < nums.length; j++) {
        sum += nums[j];
        map.put(Pair.create(i, j), sum);
    }
}

}

public int sumRange(int i, int j) {
return map.get(Pair.create(i, j));
}

用到了HashMap,~~还得自己定义对象Pair~~,**map可以当做一个容器(装载具有一定格式的数据);pair可以理解为元素(放入到容器的的一个个个体),发现pair并没有单独行动的典型用法,正常都是配合map来使用(即把pair这个元素插入到map这个容器里面)。pair 是 一种模版类型。每个pair 可以存储两个值。这两种值无限制。也可以将自己写的struct的对象放进去,去处理一对儿不同类型的值。** LeetCode讨论里,貌似有人说程序用不了,可能是没有自己定义Pair类,Java标准库里没有这个类,这个数据类型得自己定义一下才能用吧。貌似C++可以直接用,除非是两个值数据类型不同,才得自己写个struct。(这块儿不是100%确定...):| `Map<Pair<Integer, Integer>, Integer>`,并且需要一个O(n^2)的pre-computation,因为要put数据到一个二维map里。但是每个sumRange query的时间是O(1),HashTable的look up运行时长是个定值。

----
#Notes:
----

**好像**:当"pre-computation done in the constructor",在考虑sumRange方法的query's time,计算这个方法(算法)的时间复杂度时,pre- 部分可以不计入。

###Dynamic Programming(动态规划):
- 线性动规
- 区域动规
- 树形动规
- 背包问题
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 195,898评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,401评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,058评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,539评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,382评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,319评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,706评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,370评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,664评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,715评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,476评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,326评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,730评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,003评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,275评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,683评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,877评论 2 335

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,712评论 0 33
  • @清晨 草叶上的露水 和尖顶上的鸽子一样无知 假山里的圣母像 并非因为偷听祷告而埋头苦笑 讲故事的人,一边分享 一...
    塞茜尔阅读 255评论 0 2
  • 每两周幼儿园班主任都会在学生手册上备注一些可可在校情况说明,我每次都会认真阅读并注意他的那些行为习惯需要改进。很感...
    Sara_58a7阅读 610评论 0 0