国产精品天干天干,亚洲毛片在线,日韩gay小鲜肉啪啪18禁,女同Gay自慰喷水

歡迎光臨散文網(wǎng) 會(huì)員登陸 & 注冊(cè)

差分?jǐn)?shù)組詳解

2023-06-09 12:42 作者:博哥的數(shù)據(jù)結(jié)構(gòu)和算法  | 我要投稿

一維差分?jǐn)?shù)組

假設(shè)給你一個(gè)數(shù)組 nums ,先對(duì)區(qū)間 [a,b] 中每個(gè)元素加 3 ,在對(duì)區(qū)間 [c,d] 每個(gè)元素減 5 ?…… ?,這樣非常頻繁的區(qū)間修改,常規(guī)的做法可以一個(gè)個(gè)計(jì)算。

頻繁對(duì)數(shù)組的一段區(qū)間進(jìn)行增加或減去同一個(gè)值,如果一個(gè)個(gè)去操作,很明顯效率很差,我們可以使用差分?jǐn)?shù)組,差分?jǐn)?shù)組就是原始數(shù)組相鄰元素之間的差。定義差分?jǐn)?shù)組 d[n] ,我們可以得到: d[i] = nums[i] ? nums[i?1] ,其中 d[0] = nums[0] ,如下圖所示。

我們可以看到原數(shù)組就是差分?jǐn)?shù)組的前綴和。

有了差分?jǐn)?shù)組,如果對(duì)區(qū)間 [a,b] 每個(gè)元素加 3 ,不需要在一個(gè)個(gè)操作,只需要在兩端修改即可,如下圖所示。

來(lái)看下代碼:


二維差分?jǐn)?shù)組

我們把一維差分?jǐn)?shù)組看做是一條直線,只需要用后面的值減去前面的值就可以構(gòu)造差分?jǐn)?shù)組。而二維差分?jǐn)?shù)可以把他看做是一個(gè)平面,如下圖所示,他的定義如下:

如果想獲取原數(shù)組,根據(jù)上面的公式可以得到:

如下圖所示,以 (x1,y1) 為左上角, (x2,y2) 為右下角構(gòu)成一個(gè)區(qū)間,如果對(duì)這個(gè)區(qū)間內(nèi)的每個(gè)元素增加 val ,只需要執(zhí)行下面四步即可。

代碼如下:

?


差分?jǐn)?shù)組詳解的評(píng)論 (共 條)

分享到微博請(qǐng)遵守國(guó)家法律
南皮县| 江永县| 新竹县| 连平县| 樟树市| 上杭县| 沁水县| 鹤岗市| 温宿县| 沧源| 化德县| 怀宁县| 保靖县| 大姚县| 苏尼特左旗| 肥西县| 望城县| 肃南| 河曲县| 浮山县| 白河县| 河源市| 莱芜市| 达拉特旗| 宜丰县| 手游| 彩票| 垣曲县| 兰溪市| 阿鲁科尔沁旗| 洛隆县| 伊金霍洛旗| 德兴市| 龙游县| 高雄县| 金湖县| 甘泉县| 县级市| 米易县| 靖江市| 故城县|