二维差分数组(JAVA)蓝桥杯

二维差分数组可以根据二维前缀和数组移项得到,对二维差分数组b[i][j]加或者减去一个数,就意味着计算二维前缀和数组后的原数组从这个点开始到最后一个点的矩形都加上或者减去这个数。所以可以根据上面的计算。

java 复制代码
package com.js.datastructure.recursion.蓝桥;

import java.util.Scanner;

public class 二维差分 {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        int m = scanner.nextInt();
        int q = scanner.nextInt();

        int[][] a = new int[n+2][m+2];
        //操作完成后可以直接在差分数组上求前缀和
        int[][] b = new int[n+2][m+2];

        //计算差分数组
        for (int i = 1; i < n+1; i++) {
            for (int j = 1; j < m+1; j++) {
                a[i][j] = scanner.nextInt();
                b[i][j] = a[i][j] - a[i-1][j] - a[i][j-1] + a[i-1][j-1];
            }
        }

        //进行操作
        for (int i = 0; i < q; i++) {
            int x1 = scanner.nextInt();
            int y1 = scanner.nextInt();
            int x2 = scanner.nextInt();
            int y2 = scanner.nextInt();
            int d = scanner.nextInt();
            b[x1][y1] += d;
            b[x2+1][y1] -= d;
            b[x1][y2+1] -= d;
            b[x2+1][y2+1] += d;
        }

        //计算前缀和并输出原数组
        for (int i = 1; i < n+1; i++) {
            for (int j = 1; j < m+1; j++) {
                b[i][j] = b[i][j] + b[i-1][j] + b[i][j-1] - b[i-1][j-1];
                System.out.print(b[i][j] + " ");
            }
            System.out.println();
        }
    }
}
相关推荐
__万波__几秒前
二十三种设计模式(二十二)--策略模式
java·设计模式·策略模式
꧁Q༒ོγ꧂几秒前
C++ 入门完全指南(六)--指针与动态内存
开发语言·c++
不想上班的小吕1 分钟前
采购申请创建(BAPI_PR_CREATE/BAPI_REQUISITION_CREATE)
java·服务器·数据库
IT=>小脑虎3 分钟前
2026版 Go语言零基础衔接进阶知识点【详解版】
开发语言·后端·golang
ChangYan.4 分钟前
ffi-napi运行失败,报错:No native build was found,解决办法
开发语言
专注VB编程开发20年4 分钟前
压栈顺序是反向(从右往左)的,但正因为是反向压栈,所以第一个参数反而离栈顶(ESP)最近。
java·开发语言·算法
椰汁菠萝5 分钟前
spring boot下使用gdal解析tif文件
java·native·gdal·0
better_liang5 分钟前
每日Java面试场景题知识点之-ELK日志分析
java·elk·微服务·面试题·日志分析·企业级开发
图南随笔9 分钟前
Spring Boot(二十三):RedisTemplate的Set和Sorted Set类型操作
java·spring boot·redis·后端·缓存
say_fall9 分钟前
C++ 类与对象易错点:初始化列表顺序 / 静态成员访问 / 隐式类型转换
android·java·开发语言·c++