LCR 013. 二维区域和检索 - 矩阵不可变(java)

LCR 013. 二维区域和检索 - 矩阵不可变

题目

给定一个二维矩阵 matrix,以下类型的多个请求:

  • 计算其子矩形范围内元素的总和,该子矩阵的左上角为 (row1, col1) ,右下角为 (row2, col2)

实现 NumMatrix 类:

  • NumMatrix(int[][] matrix) 给定整数矩阵 matrix 进行初始化
  • int sumRegion(int row1, int col1, int row2, int col2) 返回左上角 (row1, col1) 、右下角 (row2, col2) 的子矩阵的元素总和。

示例:

解题思路:

题目求子矩阵元素的和,首先想到的是暴力解法,两个for循环,将矩阵中的元素遍历相加,但是超出了时间限制。

将暴力求和优化:

思路:

创建一个新的矩阵sums,每个元素表示该位置到已知矩阵[0, 0],元素的和,为了减少边界的判断,直接创建比原来矩阵多一行一列的sums的矩阵:

图解:

求sums矩阵

java 复制代码
  this.sums[i][j] = this.sums[i-1][j]+this.sums[i][j-1]-this.sums[i-1][j-1]+matrix[i-1][j-1];

图解:

初始化 sums矩阵后,求子矩阵元素之和:

图解:

最终求解程序:

java 复制代码
class NumMatrix {

    int[][] matrix;

    int[][] sums;
    public NumMatrix(int[][] matrix) {
       this.matrix = matrix;
        this.sums = new int[matrix.length+1][matrix[0].length+1];
        for (int i = 1; i <= matrix.length; i++) {
            for (int j = 1; j <= matrix[0].length; j++) {
               this.sums[i][j] = this.sums[i-1][j]+this.sums[i][j-1]-this.sums[i-1][j-1]+matrix[i-1][j-1];
            }
        }
    }
    public int sumRegion(int row1, int col1, int row2, int col2) {
        return this.sums[row2+1][col2+1]-this.sums[row1][col2+1]-this.sums[row2+1][col1]+this.sums[row1][col1];
    }
}
相关推荐
yaoh.wang几秒前
力扣(LeetCode) 119: 杨辉三角 II - 解法思路
数据结构·python·算法·leetcode·面试·职场和发展·跳槽
CoderCodingNo5 分钟前
【GESP】C++五级真题(埃氏筛思想考点) luogu-B3929 [GESP202312 五级] 小杨的幸运数
数据结构·c++·算法
机器学习之心15 分钟前
基于PSO-GA混合算法的施工进度计划多目标优化,以最小化总成本并实现资源均衡,满足工期约束和资源限制,MATLAB代码
算法·matlab·多目标优化·pso-ga混合算法
bbq粉刷匠17 分钟前
Java--二叉树概念及其基础应用
java·数据结构·算法
CodeByV19 分钟前
【算法题】前缀和
算法
高洁0126 分钟前
知识图谱构建
人工智能·深度学习·算法·机器学习·知识图谱
郝亚军26 分钟前
顺序栈C语言版本
c语言·开发语言·算法
AndrewHZ34 分钟前
【图像处理基石】什么是神经渲染?
图像处理·人工智能·神经网络·算法·cnn·计算机图形学·神经渲染
2401_8414956436 分钟前
【LeetCode刷题】爬楼梯
数据结构·python·算法·leetcode·动态规划·滑动窗口·斐波那契数列
byzh_rc40 分钟前
[模式识别-从入门到入土] 组合分类器
人工智能·算法·机器学习·支持向量机·概率论