题目 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;
}
相关推荐
Uu_05kkq几秒前
【C语言1】C语言常见概念(总结复习篇)——库函数、ASCII码、转义字符
c语言·数据结构·算法
清梦20201 小时前
经典问题---跳跃游戏II(贪心算法)
算法·游戏·贪心算法
Dream_Snowar2 小时前
速通Python 第四节——函数
开发语言·python·算法
Altair澳汰尔2 小时前
数据分析和AI丨知识图谱,AI革命中数据集成和模型构建的关键推动者
人工智能·算法·机器学习·数据分析·知识图谱
A懿轩A2 小时前
C/C++ 数据结构与算法【栈和队列】 栈+队列详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·栈和队列
Python机器学习AI2 小时前
分类模型的预测概率解读:3D概率分布可视化的直观呈现
算法·机器学习·分类
吕小明么3 小时前
OpenAI o3 “震撼” 发布后回归技术本身的审视与进一步思考
人工智能·深度学习·算法·aigc·agi
1 9 J3 小时前
数据结构 C/C++(实验五:图)
c语言·数据结构·c++·学习·算法
程序员shen1616114 小时前
抖音短视频saas矩阵源码系统开发所需掌握的技术
java·前端·数据库·python·算法
汝即来归4 小时前
选择排序和冒泡排序;MySQL架构
数据结构·算法·排序算法