LeetCode?動(dòng)態(tài)規(guī)劃之矩陣區(qū)域和詳情
題目
矩陣區(qū)域和
給你一個(gè) m x n
的矩陣 mat
和一個(gè)整數(shù) k
,請(qǐng)你返回一個(gè)矩陣 answer
,其中每個(gè) answer[i][j]
是所有滿足下述條件的元素 mat[r][c]
的和:
i - k <= r <= i + k
,j - k <= c <= j + k
且(r, c)
在矩陣內(nèi)。
示例 1:
輸入:mat = [[1,2,3],[4,5,6],[7,8,9]], k = 1
輸出:[[12,21,16],[27,45,33],[24,39,28]]
示例 2:
輸入:mat = [[1,2,3],[4,5,6],[7,8,9]], k = 2
輸出:[[45,45,45],[45,45,45],[45,45,45]]
提示:
m ==?mat.length n ==?mat[i].length 1 <= m, n, k <= 100 1 <= mat[i][j] <= 100
題解
解題分析
解題思路:
- 本題是以典型的動(dòng)態(tài)規(guī)劃問題;
- 獲取前綴矩陣dp[][]
dp[i+1][j+1] = dp[i][j+1]+dp[i+1][j]+arr[i][j]-dp[i][j];
根據(jù)前綴矩陣計(jì)算結(jié)果:
- 核心問題轉(zhuǎn)化為了:1).求這兩個(gè)過程的轉(zhuǎn)移方程;2). 邊界處理.
解題代碼如下所示:
復(fù)雜度
- 時(shí)間復(fù)雜度:
O(M * N)
- 空間復(fù)雜度:
O(M * N)
解題代碼
題解代碼如下(代碼中有詳細(xì)的注釋說明):
class Solution { public int[][] matrixBlockSum(int[][] mat, int k) { int m = mat.length,n = mat[0].length; int[][] dp = get_dp(mat,m,n); return get_res(dp,m,n,k); } //獲取dp數(shù)組 public int[][] get_dp(int[][] arr,int m,int n){ int[][] dp = new int[m+1][n+1]; for (int i = 0; i < m; i++) for (int j = 0; j < n; j++) dp[i+1][j+1] = dp[i][j+1]+dp[i+1][j]+arr[i][j]-dp[i][j]; return dp; } //獲取結(jié)果 public int[][] get_res(int[][] dp,int m,int n,int k){ int[][] res = new int[m][n]; int x1,y1,x2,y2; for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { x1 = Math.max(0,i-k);y1 = Math.max(0,j-k); x2 = Math.min(m,i+k+1);y2 = Math.min(n,j+k+1); res[i][j] = dp[x2][y2]-dp[x1][y2]-dp[x2][y1]+dp[x1][y1]; } } return res; } }
提交后反饋結(jié)果(由于該題目沒有進(jìn)行優(yōu)化,性能一般):
到此這篇關(guān)于LeetCode 動(dòng)態(tài)規(guī)劃之矩陣區(qū)域和詳情的文章就介紹到這了,更多相關(guān)LeetCode 矩陣區(qū)域和內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java編程中的構(gòu)造函數(shù)詳細(xì)介紹
這篇文章主要介紹了Java編程中的構(gòu)造函數(shù)詳細(xì)介紹,介紹了其概念,格式,與其他函數(shù)的區(qū)別,作用等相關(guān)內(nèi)容,具有一定參考價(jià)值,需要的朋友可以了解下。2017-11-11jdk8的datetime時(shí)間函數(shù)使用示例
這篇文章主要介紹了jdk8的datetime時(shí)間函數(shù)使用示例,需要的朋友可以參考下2014-03-03詳解SpringBoot 發(fā)布ApplicationEventPublisher和監(jiān)聽ApplicationEvent事
這篇文章主要介紹了詳解SpringBoot 發(fā)布ApplicationEventPublisher和監(jiān)聽ApplicationEvent事件,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-06-06Java 實(shí)現(xiàn)LZ78壓縮算法的示例代碼
這篇文章主要介紹了Java 實(shí)現(xiàn)LZ78壓縮算法的示例代碼,代碼簡單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05Java如何按16進(jìn)制發(fā)送和接收TCP指令
這篇文章主要介紹了Java如何按16進(jìn)制發(fā)送和接收TCP指令問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09Java如何將處理完異常之后的程序能夠從拋出異常的地點(diǎn)向下執(zhí)行?
今天小編就為大家分享一篇關(guān)于Java如何將處理完異常之后的程序能夠從拋出異常的地點(diǎn)向下執(zhí)行?,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-04-04