【统计子矩阵——部分前缀和+双指针】

题目

代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 510;
int s[N][N];
int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    
    int n, m, k;
    cin >> n >> m >> k;
    
    for(int i = 1; i <= n; i++)
        for(int j = 1; j <= m; j++)
        {
            cin >> s[i][j];
            s[i][j] += s[i-1][j];
        }
    
    ll ans =  0;
    for(int i = 1; i <= n; i++)
    {
        for(int j = i; j <= n; j++)
        {
            for(int l = 1, r = 1, sum = 0; r <= m; r++)
            {
                sum += s[j][r] - s[i-1][r];
                while(sum > k)
                {
                    sum -= s[j][l] - s[i-1][l];
                    l++;
                }
                
                ans += r - l + 1;
            }
        }
    }
    
    cout << ans;
}
相关推荐
菜菜的顾清寒21 分钟前
力扣HOT100(34)图论-岛屿数量
算法·leetcode·图论
名字不好奇23 分钟前
大模型的思考模式:它真的在“想“吗?
人工智能·算法
Run_Teenage32 分钟前
算法模板:输入输出,并查集
java·开发语言·算法
高一学习c++会秃头吗41 分钟前
操作系统内存块分配算法
算法
洛水水43 分钟前
【力扣100题】57.合并区间
算法·leetcode
玉树临风ives44 分钟前
atcoder ABC 458 题解
数据结构·c++·算法
如竟没有火炬1 小时前
有序矩阵中第K小的元素
数据结构·线性代数·算法·leetcode·矩阵·深度优先
叁散1 小时前
ESP32智能闹钟系统实验报告
单片机·嵌入式硬件·算法
Realdagongzai1 小时前
Linux 6.19.10 内核调度器算法详解
linux·学习·算法·spring·kernel
洛水水2 小时前
【力扣100题】63.最小覆盖子串
算法·leetcode