欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

LeetCode?動態(tài)規(guī)劃之矩陣區(qū)域和詳情

 更新時間:2022年04月22日 10:41:17   作者:心城以北  
這篇文章主要介紹了LeetCode?動態(tài)規(guī)劃之矩陣區(qū)域和詳情,文章基于Java的相關資料展開對LeetCode?動態(tài)規(guī)劃的詳細介紹,需要的小伙伴可以參考一下

題目

矩陣區(qū)域和

給你一個 m x n 的矩陣 mat 和一個整數(shù) k ,請你返回一個矩陣 answer ,其中每個 answer[i][j] 是所有滿足下述條件的元素 mat[r][c] 的和: 

i - k <= r <= i + k,
j - k <= c <= j + k 且
(r, c) 在矩陣內。  

示例 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

題解

解題分析

解題思路:

  • 本題是以典型的動態(tài)規(guī)劃問題;
  • 獲取前綴矩陣dp[][]
dp[i+1][j+1] = dp[i][j+1]+dp[i+1][j]+arr[i][j]-dp[i][j];

根據前綴矩陣計算結果:

  • 核心問題轉化為了:1).求這兩個過程的轉移方程;2). 邊界處理.

解題代碼如下所示:

復雜度

  • 時間復雜度: O(M * N)
  • 空間復雜度: O(M * N)

解題代碼

題解代碼如下(代碼中有詳細的注釋說明):

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;
    }
    //獲取結果
    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;
    }
}

提交后反饋結果(由于該題目沒有進行優(yōu)化,性能一般):

image.png

到此這篇關于LeetCode 動態(tài)規(guī)劃之矩陣區(qū)域和詳情的文章就介紹到這了,更多相關LeetCode 矩陣區(qū)域和內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 使用java生成字母驗證碼

    使用java生成字母驗證碼

    這篇文章主要介紹了使用java生成字母驗證碼的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • Java編程中的構造函數(shù)詳細介紹

    Java編程中的構造函數(shù)詳細介紹

    這篇文章主要介紹了Java編程中的構造函數(shù)詳細介紹,介紹了其概念,格式,與其他函數(shù)的區(qū)別,作用等相關內容,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • jdk8的datetime時間函數(shù)使用示例

    jdk8的datetime時間函數(shù)使用示例

    這篇文章主要介紹了jdk8的datetime時間函數(shù)使用示例,需要的朋友可以參考下
    2014-03-03
  • 詳解SpringBoot 發(fā)布ApplicationEventPublisher和監(jiān)聽ApplicationEvent事件

    詳解SpringBoot 發(fā)布ApplicationEventPublisher和監(jiān)聽ApplicationEvent事

    這篇文章主要介紹了詳解SpringBoot 發(fā)布ApplicationEventPublisher和監(jiān)聽ApplicationEvent事件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06
  • Java 實現(xiàn)LZ78壓縮算法的示例代碼

    Java 實現(xiàn)LZ78壓縮算法的示例代碼

    這篇文章主要介紹了Java 實現(xiàn)LZ78壓縮算法的示例代碼,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05
  • 解決SpringBoot @value注解取不到值的問題

    解決SpringBoot @value注解取不到值的問題

    這篇文章主要介紹了解決SpringBoot @value注解取不到值的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Java如何按16進制發(fā)送和接收TCP指令

    Java如何按16進制發(fā)送和接收TCP指令

    這篇文章主要介紹了Java如何按16進制發(fā)送和接收TCP指令問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Java 將Excel轉為SVG的方法

    Java 將Excel轉為SVG的方法

    本文以Java示例展示如何將Excel文檔轉為SVG格式。通過本文中的方法,在將Excel轉為SVG時,如果sheet工作表中手動設置了分頁,則將每個分頁的內容單獨保存為一個svg文件,如果sheet工作表中沒有設置分頁,則將Excel sheet表格中默認的分頁范圍保存為svg。
    2021-05-05
  • MyBatis使用動態(tài)表或列代碼解析

    MyBatis使用動態(tài)表或列代碼解析

    這篇文章主要介紹了MyBatis使用動態(tài)表或列代碼解析,分享了相關代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Java如何將處理完異常之后的程序能夠從拋出異常的地點向下執(zhí)行?

    Java如何將處理完異常之后的程序能夠從拋出異常的地點向下執(zhí)行?

    今天小編就為大家分享一篇關于Java如何將處理完異常之后的程序能夠從拋出異常的地點向下執(zhí)行?,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-04-04

最新評論