蓝桥杯题目:二维前缀和

首先分析一下二维数组的差分。s[x2][y2]-s[x1][y1]=s[x2][y2]-s[x2][y1-1]-s[x1-1][y2]+s[x1-1][y1-1]

因为对于二维数组x2y2-x1y1范围内的值需要通过x2y2减去从x1,y2-1的这段存储的前缀和以及减去x2-1,y1这两部分的前缀和,但是还有一个x1-1,y1-1这一段被减去了两次。我们可以通过举例例如:sum (2,2)∼(3,3)=sum 3,3−sum 1,3−sum 3,1+sum 1,1

以及二维数组的前缀和怎么求对于横轴来书和一维数组一样。s[i][j]=s[i-1][j]+a[i][j]

对于纵轴来说s[i][j]=s[i][j]+s[i][j-1];

通过举例可得

sum (3,3)=sum2 ,3+a[3,1]+a[3,2]+a[3,3]

以下是代码实现

复制代码
package 二维数组前缀和;

import java.util.Scanner;
// 1:无需package
// 2: 类名必须Main, 不可修改

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);


        int n=scan.nextInt();
        int m=scan.nextInt();
        int q=scan.nextInt();
        long [][] a=new long[n+1][m+1];
        long [][] s=new long[n+1][m+1];

        for(int i=1;i<=n;i++)
        {
            for(int j=1;j<=m;j++)
            {
                a[i][j]=scan.nextInt();
                s[i][j]=s[i][j-1]+a[i][j];

            }
            for (int j = 1; j <= m; j++) {
                s[i][j] += s[i - 1][j];  // 二维前缀和处理
            }

        }
        for(int i=0;i<q;i++)
        {
            int x1=scan.nextInt();
            int y1=scan.nextInt();
            int x2=scan.nextInt();
            int y2=scan.nextInt();
            System.out.println(caculate(x1,y1,x2,y2,s));

        }


        //在此输入您的代码...
        scan.close();
    }
    public static long caculate(int x1,int y1,int x2,int y2,long [][] s)
    {

        if(x1>x2||y1>y2)
        {
            return 0;
        }



        return s[x2][y2]-s[x2][y1-1]-s[x1-1][y2]+s[x1-1][y1-1];

    }
}
相关推荐
花花鱼1 天前
Spring Security 与 Spring MVC
java·spring·mvc
无敌昊哥战神1 天前
深入理解 C 语言:巧妙利用“0地址”手写 offsetof 宏与内存对齐机制
c语言·数据结构·算法
小白菜又菜1 天前
Leetcode 2075. Decode the Slanted Ciphertext
算法·leetcode·职场和发展
Proxy_ZZ01 天前
用Matlab绘制BER曲线对比SPA与Min-Sum性能
人工智能·算法·机器学习
黎阳之光1 天前
黎阳之光:以视频孪生领跑全球,赋能数字孪生水利智能监测新征程
大数据·人工智能·算法·安全·数字孪生
言慢行善1 天前
sqlserver模糊查询问题
java·数据库·sqlserver
专吃海绵宝宝菠萝屋的派大星1 天前
使用Dify对接自己开发的mcp
java·服务器·前端
小李子呢02111 天前
前端八股6---v-model双向绑定
前端·javascript·算法
大数据新鸟1 天前
操作系统之虚拟内存
java·服务器·网络
Tong Z1 天前
常见的限流算法和实现原理
java·开发语言