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倍。

相关推荐
努力学习编程的伍大侠9 分钟前
基础排序算法
数据结构·c++·算法
XiaoLeisj37 分钟前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
Jasmine_llq1 小时前
《 火星人 》
算法·青少年编程·c#
闻缺陷则喜何志丹1 小时前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径
Lenyiin1 小时前
01.02、判定是否互为字符重排
算法·leetcode
鸽鸽程序猿2 小时前
【算法】【优选算法】宽搜(BFS)中队列的使用
算法·宽度优先·队列
Jackey_Song_Odd2 小时前
C语言 单向链表反转问题
c语言·数据结构·算法·链表
Watermelo6172 小时前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
乐之者v2 小时前
leetCode43.字符串相乘
java·数据结构·算法