2536. 子矩阵元素加 1

跳转题目

本题暴力可以做,猜到用差分,但是不熟,不知道二维差分怎么用,碰到用差分的题目太少了。

暴力算法:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> rangeAddQueries(int n, vector<vector<int>>& queries) {
    vector<vector<int>> ans(n,vector<int>(n,0));
    for(vector<int> it:queries){
        for(int i=it[0];i<=it[2];i++){
            for(int j=it[1];j<=it[3];j++){
                ans[i][j]++;
            }
        }
    }
    return ans;
    }
};

二维差分:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> rangeAddQueries(int n, vector<vector<int>>& queries) {
    vector<vector<int>> ans(n,vector<int>(n,0));
    vector<vector<int>> diff(n+1,vector<int>(n+1,0));
    for(vector<int> it:queries){
        diff[it[0]][it[1]]++;
        diff[it[2]+1][it[3]+1]++;
        diff[it[0]][it[3]+1]--;
        diff[it[2]+1][it[1]]--;
    }
    for(int i=0;i<n;i++)
        for(int j=1;j<n;j++) diff[i][j]+=diff[i][j-1];
    
    for(int i=1;i<n;i++)
        for(int j=0;j<n;j++) diff[i][j]+=diff[i-1][j];
    
    for(int i=0;i<n;i++)
        for(int j=0;j<n;j++) ans[i][j]=diff[i][j];
    return ans;
    }
};

思路参考:https://leetcode.cn/problems/increment-submatrices-by-one/solutions/2684930/er-wei-chai-fen-qiu-qian-zhui-he-shi-hen-i8g5/

多耗费10mb的空间,速度提高了10倍。

相关推荐
AIFarmer12 分钟前
【无标题】
开发语言·c++·算法
AGV算法笔记33 分钟前
CVPR 2025 最新感知算法解读:GaussianLSS 如何用 Gaussian Splatting 重构 BEV 表示?
算法·重构·自动驾驶·3d视觉·感知算法·多视角视觉
勤劳的进取家1 小时前
数据链路层基础
网络·学习·算法
Advancer-2 小时前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤2 小时前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法
superior tigre3 小时前
78 子集
算法·leetcode·深度优先·回溯
天威?*3 小时前
bitset的数据结构用法
算法·动态规划
hoiii1873 小时前
粒子滤波跟踪系统 - 蒙特卡洛方法实现
算法
weisian1514 小时前
Java并发编程--47-分布式ID生成器:雪花算法(Snowflake)与时钟回拨问题
java·算法·时钟回拨·雪花算法id
itzixiao4 小时前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法