题目 3161: 蓝桥杯2023年第十四届省赛真题-子矩阵

题目

代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1010, mod = 998244353;
int g[N][N];
int rmin[N][N], rmax[N][N];
ll mmin[N][N], mmax[N][N];
int q[N * N];
int hh, tt;
int n, m, a, b;
int main()
{
  cin >> n >> m >> a >> b;
  for (int i = 1; i <= n; i++)
  {
    for (int j = 1; j <= m; j++)
    {
      cin >> g[i][j];
    }
  }

  for (int i = 1; i <= n; i++)
  {
    hh = 0, tt = -1;
    for (int j = 1; j <= m; j++)
    {
      if (hh <= tt && j - q[hh] + 1 > b)
        hh++;
      while (hh <= tt && g[i][q[tt]] >= g[i][j])
        tt--;
      q[++tt] = j;
      if (j >= b)
        rmin[i][j - b + 1] = g[i][q[hh]];
    }
  }

  for (int j = 1; j <= m; j++)
  {
    hh = 0, tt = -1;
    for (int i = 1; i <= n; i++)
    {
      if (hh <= tt && i - q[hh] + 1 > a)
        hh++;
      while (hh <= tt && rmin[q[tt]][j] >= rmin[i][j])
        tt--;
      q[++tt] = i;
      if (i >= a)
        mmin[i - a + 1][j] = rmin[q[hh]][j];
    }
  }

  for (int i = 1; i <= n; i++)
  {
    hh = 0, tt = -1;
    for (int j = 1; j <= m; j++)
    {
      if (hh <= tt && j - q[hh] + 1 > b)
        hh++;
      while (hh <= tt && g[i][q[tt]] <= g[i][j])
        tt--;
      q[++tt] = j;
      if (j >= b)
        rmax[i][j - b + 1] = g[i][q[hh]];
    }
  }

  for (int j = 1; j <= m; j++)
  {
    hh = 0, tt = -1;
    for (int i = 1; i <= n; i++)
    {
      if (hh <= tt && i - q[hh] + 1 > a)
        hh++;
      while (hh <= tt && rmax[q[tt]][j] <= rmax[i][j])
        tt--;
      q[++tt] = i;
      if (i >= a)
        mmax[i - a + 1][j] = rmax[q[hh]][j];
    }
  }

  ll ans = 0;
  for (int i = 1; i + a - 1 <= n; i++)
  {
    for (int j = 1; j + b - 1 <= m; j++)
    {
      ans = (ans + (mmin[i][j] * mmax[i][j]) % mod) % mod;
    }
  }

  cout << ans;
}
相关推荐
李老师讲编程2 分钟前
C++信息学奥赛练习题-杨辉三角
数据结构·c++·算法·青少年编程·信息学奥赛
zxsz_com_cn12 分钟前
设备预测性维护算法核心功能有哪些?六大模块拆解智能运维的“技术骨架”
运维·算法
期末考复习中,蓝桥杯都没时间学了14 分钟前
力扣刷题13
数据结构·算法·leetcode
2201_7569890924 分钟前
C++中的事件驱动编程
开发语言·c++·算法
多米Domi01135 分钟前
0x3f 第48天 面向实习的八股背诵第五天 + 堆一题 背了JUC的题,java.util.Concurrency
开发语言·数据结构·python·算法·leetcode·面试
2301_8223776536 分钟前
模板元编程调试方法
开发语言·c++·算法
故以往之不谏1 小时前
函数--值传递
开发语言·数据结构·c++·算法·学习方法
渐暖°1 小时前
【leetcode算法从入门到精通】5. 最长回文子串
vscode·算法·leetcode
今天_也很困1 小时前
LeetCode热题100-560. 和为 K 的子数组
java·算法·leetcode
v_for_van1 小时前
力扣刷题记录2(无算法背景,纯C语言)
c语言·算法·leetcode