【算法】798. 差分矩阵

题目

798. 差分矩阵

思路

实质是二维差分,构造数组b,a为b的前缀和,也要用到前缀和的内容,求出数组b之后用b表示a,和一维差分思路类似,不同之处是在加减c时二维要复杂一些。

代码

cpp 复制代码
#include<iostream>
using namespace std;
const int N=1010;
int a[N][N],b[N][N];
void insert(int x1,int y1,int x2,int y2,int c)
{
    b[x1][y1]=b[x1][y1]+c;
    b[x2+1][y1]=b[x2+1][y1]-c;
    b[x1][y2+1]=b[x1][y2+1]-c;
    b[x2+1][y2+1]=b[x2+1][y2+1]+c;
}
int main()
{
    int n,m,q;
    scanf("%d %d %d",&n,&m,&q);
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            scanf("%d",&a[i][j]);
        }
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            b[i][j]=a[i][j]-a[i-1][j]-a[i][j-1]+a[i-1][j-1];
        }
    }
    while(q--)
    {
        int x1,y1,x2,y2,c;
        cin>>x1>>y1>>x2>>y2>>c;
        insert(x1,y1,x2,y2,c);
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            a[i][j]=a[i-1][j]+a[i][j-1]-a[i-1][j-1]+b[i][j];
        }
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            printf("%d ",a[i][j]);
        }
        printf("\n");
    }
    return 0;
}
相关推荐
寂静山林6 小时前
UVa 1030 Image Is Everything
算法
AI柠檬6 小时前
几种排序算法的实现和性能比较
数据结构·算法·c#·排序算法
望十五江洋6 小时前
泊松分布的参数可加性
线性代数·机器学习·概率论
西西弗Sisyphus7 小时前
线性代数 - 初等矩阵
人工智能·线性代数·机器学习
weixin_429630267 小时前
第6章 支持向量机
算法·机器学习·支持向量机
SweetCode7 小时前
C++ 实现大数加法
开发语言·c++·算法
王哈哈^_^7 小时前
【数据集】【YOLO】【目标检测】共享单车数据集,共享单车识别数据集 3596 张,YOLO自行车识别算法实战训推教程。
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
追赶sun8 小时前
讨论矩阵等价、相似的几何含义
线性代数
CodeWizard~8 小时前
AtCoder Beginner Contest 430赛后补题
c++·算法·图论
大大dxy大大8 小时前
机器学习-KNN算法示例
人工智能·算法·机器学习