區(qū)域和檢索 - 數(shù)組不可變

題目描述

難度級別:簡單

給定一個整數(shù)數(shù)組 nums,求出數(shù)組從索引 i 到 j(i ≤ j)范圍內元素的總和,包含 i杰赛、j 兩點。

實現(xiàn) NumArray 類:

NumArray(int[] nums) 使用數(shù)組 nums 初始化對象
int sumRange(int i, int j) 返回數(shù)組 nums 從索引 i 到 j(i ≤ j)范圍內元素的總和矮台,包含 i乏屯、j 兩點(也就是 sum(nums[i], nums[i + 1], ... , nums[j]))

示例:

輸入:
["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))

提示:

0 <= nums.length <= 104
-105 <= nums[i] <= 105
0 <= i <= j < nums.length
最多調用 104 次 sumRange 方法

解題思路

法一

保存數(shù)組,然后sumrange根據(jù)不同的索引計算分別計算它們的和瘦赫。

/**
 * @param {number[]} nums
 */
var NumArray = function(nums) {
    this.array = nums
};

/** 
 * @param {number} i 
 * @param {number} j
 * @return {number}
 */
NumArray.prototype.sumRange = function(i, j) {
    let count = 0

    for(let k = i; k <= j; k++)
        count += this.array[k]
    
    return count
};

/**
 * Your NumArray object will be instantiated and called as such:
 * var obj = new NumArray(nums)
 * var param_1 = obj.sumRange(i,j)
 */

緩存

通過緩存辰晕,創(chuàng)建一個對nums從0到第n項得的和的數(shù)組。當需要求范圍內數(shù)組的和時确虱,末項 + 1減去第 i 項含友,如下

nums:0 1 2 4 5 6 7
this.array:0 0 1 3 7 12 18 25
求3到4項數(shù)的和:即前4項的和 7 減去前2項得和1為6。2+4也得6校辩。

/**
 * @param {number[]} nums
 */
var NumArray = function(nums) {
    this.array = new Array(nums.length + 1).fill(0)

    for(let i = 0; i < nums.length; i++) {
        this.array[i + 1] += this.array[i] + nums[i]
    }
};

/** 
 * @param {number} i 
 * @param {number} j
 * @return {number}
 */
NumArray.prototype.sumRange = function(i, j) {
    return this.array[j + 1] - this.array[i]
};

/**
 * Your NumArray object will be instantiated and called as such:
 * var obj = new NumArray(nums)
 * var param_1 = obj.sumRange(i,j)
 */

題目來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/range-sum-query-immutable

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末窘问,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子宜咒,更是在濱河造成了極大的恐慌惠赫,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件故黑,死亡現(xiàn)場離奇詭異儿咱,居然都是意外死亡,警方通過查閱死者的電腦和手機场晶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門混埠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人诗轻,你說我怎么就攤上這事钳宪。” “怎么了扳炬?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵吏颖,是天一觀的道長。 經常有香客問我鞠柄,道長侦高,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任厌杜,我火速辦了婚禮奉呛,結果婚禮上,老公的妹妹穿的比我還像新娘夯尽。我一直安慰自己瞧壮,他們只是感情好,可當我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布匙握。 她就那樣靜靜地躺著咆槽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪圈纺。 梳的紋絲不亂的頭發(fā)上秦忿,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天麦射,我揣著相機與錄音,去河邊找鬼灯谣。 笑死潜秋,一個胖子當著我的面吹牛,可吹牛的內容都是我干的胎许。 我是一名探鬼主播峻呛,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼辜窑!你這毒婦竟也來了钩述?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤穆碎,失蹤者是張志新(化名)和其女友劉穎牙勘,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體惨远,經...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡谜悟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了北秽。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片葡幸。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖贺氓,靈堂內的尸體忽然破棺而出蔚叨,到底是詐尸還是另有隱情,我是刑警寧澤辙培,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布蔑水,位于F島的核電站,受9級特大地震影響扬蕊,放射性物質發(fā)生泄漏搀别。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一尾抑、第九天 我趴在偏房一處隱蔽的房頂上張望歇父。 院中可真熱鬧,春花似錦再愈、人聲如沸榜苫。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽垂睬。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間驹饺,已是汗流浹背钳枕。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留逻淌,地道東北人么伯。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像卡儒,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子俐巴,可洞房花燭夜當晚...
    茶點故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內容