lc2536.子矩阵元素加1

**暴力解法:**直接按照题目所示在矩阵的相应位置加一

时间复杂度:O(n 2 * queries.length)

空间复杂度:O(1)

**二维差分:**创建二维差分数组,通过对差分数组的修改来影响原来的数组,最后还原

时间复杂度:O(n 2 + queries.length)

空间复杂度:O(n 2 )

示例2此种情况会发生角标越界的情况,因此差分数组需要多初始化2行2列

代码

复制代码
import org.junit.Test;

public class SubmatrixPlus {

    @Test
    public void test() {
        int[][] queries = new int[][]{{1, 1, 2, 2}, {0, 0, 1, 1}};
        for (int[] query : submatrixPlus(queries, 3)) {
            for (int n : query) {
                System.out.print(n + " ");
            }
            System.out.println();
        }

        int[][] queries1 = new int[][]{{0, 0, 1, 1}};
        for (int[] query : submatrixPlus(queries1, 2)) {
            for (int n : query) {
                System.out.print(n + " ");
            }
            System.out.println();
        }
    }

    //int[][] querries = {{左上角行,左上角列,右下角行,右下角列},{左上角行,左上角列,右下角行,右下角列}}
    public static int[][] submatrixPlus(int[][] queries, int n) {
        // 构建差分数组,多初始化2行2列避免数组越界
        int[][] arr = new int[n][n];
        for (int i = 0; i < queries.length; i++) {
            arr[queries[i][0] + 1][queries[i][1] + 1]++;//第几行不等于数组的索引
            arr[queries[i][2] + 2][queries[i][1] + 1]--;
            arr[queries[i][0] + 1][queries[i][3] + 2]--;
            arr[queries[i][2] + 2][queries[i][3] + 2]++;
        }
        //还原数组
        int[][] res = new int[n + 2][n + 2];
        for (int i = 0; i < res.length; i++) {
            for (int j = 0; j < res[i].length; j++) {
                arr[i + 1][j + 1] = arr[i + 1][j + 1] + arr[i + 1][j] + arr[i][j + 1] - arr[i][j];
                res[i][j] = arr[i + 1][j + 1];
            }
        }
        return res;

    }
}
相关推荐
霁月中14 分钟前
[Codeforces Round 1065 (Div. 3)](A-D,F)
算法
世洋Blog17 分钟前
算法导论-分治法和合并(Merge)排序
算法
源代码•宸22 分钟前
Golang基础语法(go语言结构体、go语言数组与切片、go语言条件句、go语言循环)
开发语言·经验分享·后端·算法·golang·go
l1t29 分钟前
快速加载CSV文件到数据库的工具pg_csv_loader
数据库·算法
yugi98783836 分钟前
基于Matlab的晴空指数计算实现
开发语言·算法·matlab
ADI_OP1 小时前
ADAU1452的开发教程3:常规音频算法的开发(2)
算法·dsp开发·adi dsp中文资料·adi dsp·adi音频dsp·adi dsp开发教程
666HZ6661 小时前
数据结构1.0 数据结构在学什么
数据结构·算法
君义_noip1 小时前
信息学奥赛一本通 1951:【10NOIP普及组】导弹拦截 | 洛谷 P1158 [NOIP 2010 普及组] 导弹拦截
c++·算法·csp-j·信息学奥赛
环黄金线HHJX.1 小时前
《QuantumTuan ⇆ QT:Qt》
人工智能·qt·算法·编辑器·量子计算
jz_ddk1 小时前
[实战] 射频相位噪声单位转换:从dBc/Hz到rad
算法·rf·射频·相位噪声·相噪