P9905 [COCI 2023/2024 #1] AN2DL 【矩阵区间最大值】

news2024/12/25 1:18:20

文章目录

    • 题目大意
      • 1.输入格式
      • 2.输出格式
      • 3.数据范围与约定
    • 思路
      • 维护每一行区间
      • 维护每一列区间
      • 维护区间最大值
      • code↓
    • 完结撒花( ̄▽ ̄) /

题目大意

给定 n , m , r , s n,m,r,s n,m,r,s 和一个 n × m n\times m n×m 的整数矩阵 A A A,求它每个 r × s r\times s r×s 的子矩阵的元素最大值。

1.输入格式

第一行两个整数 n , m n,m n,m 表示矩阵的高和宽。

接下来 n n n 行每行 m m m 个整数,表示矩阵 A A A

最后一行两个整数 r , s r,s r,s

2.输出格式

n − r + 1 n-r+1 nr+1 行,每行 m − s + 1 m-s+1 ms+1 个数,第 i i i j j j 列的数表示以 ( i , j ) (i,j) (i,j) 为左上角的 r × s r\times s r×s 的子矩阵元素的最大值,即 max ⁡ i ≤ x ≤ i + r − 1 , j ≤ y ≤ j + s − 1 A x , y \max\limits_{i\leq x\leq i+r-1,j\leq y\leq j+s-1}A_{x,y} ixi+r1,jyj+s1maxAx,y

3.数据范围与约定

对于 100 % 100\% 100% 的数据, 1 ≤ n , m ≤ 4000 1\leq n,m\leq 4000 1n,m4000 ∣ A i , j ∣ ≤ 10000 \lvert A_{i,j}\rvert\leq 10000 Ai,j10000 1 ≤ r ≤ n 1\leq r\leq n 1rn 1 ≤ s ≤ m 1\leq s\leq m 1sm

子任务特殊性质分值
1 1 1 n , m ≤ 40 n,m\leq 40 n,m40 r = n r=n r=n s = m s=m s=m 12 12 12
2 2 2 n , m ≤ 40 n,m\leq 40 n,m40 17 17 17
3 3 3 n , m ≤ 1000 n,m\leq 1000 n,m1000 25 25 25
4 4 4无特殊性质 56 56 56

思路

这道题我们可以用单调队列来维护矩阵最大值和矩阵最小值

先维护每一排的区间 ( i ∼ i + r ) (i\sim i+r) (ii+r)的最大值

可以用code来输出区间的起始值↓

#include <bits/stdc++.h>
using namespace std;
int main(){
	int n,m,r,s;
	cin>>n>>m>>r>>s;
	for(int i=1;i<=n-r+1;i++){
		for(int j=1;j<=m-s+1;j++){
			cout<<"("<<i<<","<<j<<")"<<endl;
		}
	}
	return 0;
}

运行结果如下↓

在这里插入图片描述
此图中的 ( x , y ) (x,y) (x,y)就是区间起始点

例如 ( 2 , 3 ) (2,3) (2,3)就如下图↓
在这里插入图片描述
图中用红色方框框起来的便是 ( 2 , 3 ) (2,3) (2,3)表示的整个区间

其中 × \times ×标起来的地方便是区间起始点,也就是 ( 2 , 3 ) (2,3) (2,3)

维护每一行区间

我们要维护每一列的最大值,而每一列区间起始点可用代码输出↓

#include <bits/stdc++.h>
using namespace std;
int main(){
	int n,m,r,s;
	cin>>n>>m>>r>>s;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m-s+1;j++){
			cout<<"("<<i<<","<<j<<")"<<endl;
		}
	}
	return 0;
}

运行结果如下↓

在这里插入图片描述
在如下图可用 × \times ×表示,下图用 × \times ×依次表示了 ( 1 , 1 ) (1,1) (1,1) ( 2 , 2 ) (2,2) (2,2) ( 3 , 3 ) (3,3) (3,3) ( 4 , 1 ) (4,1) (4,1)横排区间所在的起始点
在这里插入图片描述

维护每一列区间

我们要维护每一列区间的最大值,而每一列区间起始点可用代码输出↓

#include <bits/stdc++.h>
using namespace std;
int main(){
	int n,m,r,s;
	cin>>n>>m>>r>>s;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m-s+1;j++){
			cout<<"("<<i<<","<<j<<")"<<endl;
		}
	}
	return 0;
}

在如下图可用 × \times ×表示,下图用 × \times ×依次表示了 ( 1 , 1 ) (1,1) (1,1) ( 2 , 2 ) (2,2) (2,2) ( 3 , 3 ) (3,3) (3,3) ( 1 , 4 ) (1,4) (1,4) ( 2 , 5 ) (2,5) (2,5)竖列区间所在的起始点
在这里插入图片描述

维护区间最大值

整个区间的最大值都会集中在code↓

	for(int i=1;i<=n-r+1;i++)
		for(int j=1;j<=m-s+1;j++)

如下图↓
在这里插入图片描述
图中的 × \times ×表示的就是区间最大值所在的位置

只需要将纵列单调队列横排单调队列进行合并即可,其中ans[]数组便是用来存储区间最大值的数组

code↓

#include <bits/stdc++.h>
using namespace std;
int n,m,a[4005][4005],ans[4005][4005],r,s,b[4005][4005];//ans是答案数组,n行,m列,求r行,s列的矩阵最大值
int main(){
	cin>>n>>m;
	ios::sync_with_stdio(false);
	cin.tie(0),cout.tie(0);
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cin>>a[i][j];//输入初始矩阵
		}
	}
	cin>>r>>s;//输入需要求的矩阵的行数和列数
	for(int i=1;i<=n;i++){
		deque<int> mx;//定义一个单调队列,用来存储横排的序号
		for(int j=1;j<=m;j++){
			while(!mx.empty()&&a[i][mx.back()]<=a[i][j]) mx.pop_back();//判断是否非空,满足单调性
			mx.push_back(j);//将j给压入mx这个队列
			while(!mx.empty()&&mx.front()<=j-s) mx.pop_front();//队列的头不在这个区间内,将它弹出
			if(j>=s) b[i][j-s+1]=a[i][mx.front()]; //求出a[i][j]~a[i][j+s]这个区间中的最大值
		}
	}
	for(int j=1;j<=m-s+1;j++){//区间的竖列起点是1~(m-s+1)
		deque<int> mn;//定义一个单调队列,用来存储竖列的序号
		for(int i=1;i<=n;i++){
			while(!mn.empty()&&b[mn.back()][j]<=b[i][j]) mn.pop_back();//判断是否非空,用竖列的序号去满足单调性
			mn.push_back(i);//将j压入mn这个序列
			while(!mn.empty()&&mn.front()<=i-r) mn.pop_front();//求出竖列中的区间最大值
			if(i>=r) ans[i-r+1][j]=b[mn.front()][j];//这里是求出数列中的区间最大值,ans数组来进行存储,最后输出就行
		}		
	}
	for(int i=1;i<=n-r+1;i++){//横列开始的起点
		for(int j=1;j<=m-s+1;j++){//竖列开始的起点
			cout<<ans[i][j]<<' ';//输出答案
		}
		cout<<endl;
	}
	return 0;
}

完结撒花( ̄▽ ̄) /

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1487143.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PyTorch-神经网络

神经网络&#xff0c;这也是深度学习的基石&#xff0c;所谓的深度学习&#xff0c;也可以理解为很深层的神经网络。说起这里&#xff0c;有一个小段子&#xff0c;神经网络曾经被打入了冷宫&#xff0c;因为SVM派的崛起&#xff0c;SVM不了解的同学可以去google一下&#xff0…

Android 多桌面图标启动, 爬坑点击打开不同页面

备注 &#xff1a; MainActivity 正常带界面的UI MainActivityBt 和 MainActivityUsb 是透明的&#xff0c;即 android:theme"style/TranslucentTheme" ###场景1:只有MainActivity 设置成&#xff1a;android:launchMode"singleTask" 点击顺序&#xff1…

外贸网站模板建站

测绘检测wordpress外贸主题 简洁实用的wordpress外贸主题&#xff0c;适合做测绘检测仪器设备的外贸公司使用。 https://www.jianzhanpress.com/?p5337 白马非马衣服WordPress外贸建站模板 白马非马服装行业wordpress外贸建站模板&#xff0c;适用于时间服装企业的官方网站…

ehcache3介绍和使用示例

介绍 EhCache是一个广泛使用的Java进程内缓存框架&#xff0c;具有快速和精干的特点。它提供了以下主要优势&#xff1a; 速度快&#xff1a;由于其直接在JVM进程中运行&#xff0c;EhCache的访问速度非常快&#xff0c;适合对响应时间要求较高的应用。 配置灵活&#xff1a;…

使用 Haproxy 搭建Web群集

Haproxy是目前比较流行的一种群集调度工具&#xff0c;同类群集调度工具有很多&#xff0c;如LVS 和Nginx。相比较而言&#xff0c;LVS.牲能最好&#xff0e;但是搭建相对复杂:Nginx的upstream模块支持群集功能&#xff0e;但是对群集节点健康检查功能不强&#xff0c;性能没有…

GEE:使用ReLu激活函数对单波段图像进行变换(以NDVI为例)

作者:CSDN @ _养乐多_ 本文将介绍在 Google Earth Engine (GEE)平台上,对任意单波段影像进行 ReLu 变换的代码。并以对 NDVI 影像像素值的变换为例。 文章目录 一、ReLu激活函数1.1 什么是 ReLu 激活函数1.2 用到遥感图像上有什么用?二、代码链接三、完整代码一、ReLu激活…

HTML5:七天学会基础动画网页6

CSS3自定义字体 ①&#xff1a;首先需要下载所需字体 ②&#xff1a;把下载字体文件放入 font文件夹里&#xff0c;建议font文件夹与 css 和 image文件夹平级 ③&#xff1a;引入字体&#xff0c;可直接在html文件里用font-face引入字体&#xff0c;分别是字体名字和路径 例…

【C++ 函数栈】栈区保存函数参数和函数调用的过程

目录 1 调用过程 &#x1f64b;‍♂️ 作者&#xff1a;海码007&#x1f4dc; 专栏&#xff1a;C专栏&#x1f4a5; 标题&#xff1a;【C 函数栈】栈区保存函数参数和函数调用的过程❣️ 寄语&#xff1a;人生的意义或许可以发挥自己全部的潜力&#xff0c;所以加油吧&#xff…

循环队列与循环双端队列

文章目录 前言循环队列循环双端队列 前言 1、学习循环队列和循环双端队列能加深我们对队列的理解&#xff0c;提高我们的编程能力。 2、本文循环队列使用的是数组&#xff0c;循环双端队列用的是双向链表 3、题目连接&#xff1a;设计循环队列 &#xff0c;设计循环双端队列。 …

C++面试宝典第34题:整数反序

题目 给出一个不多于5位的整数, 进行反序处理。要求: 1、求出它是几位数。 2、分别输出每一位数字。仅数字间以空格间隔, 负号与数字之间不需要间隔。如果是负数,负号加在第一个数字之前, 与数字没有空格间隔。注意:最后一个数字后没有空格。 3、按逆序输出各位数字。逆序后…

华为od机试C卷-开源项目热度榜单

1、题目描述 某个开源社区希望将最近热度比较高的开源项目出一个榜单&#xff0c;推荐给社区里面的开发者。 对于每个开源项目&#xff0c;开发者可以进行关注(watch)、收藏(star)、fork、提issue、提交合并请求(MR)等。 数据库里面统计了每个开源项目关注、收藏、fork、issue…

适用于恢复iOS数据的 10 款免费 iPhone 恢复软件

现在&#xff0c;您可以获得的 iPhone 的存储容量比大多数人的笔记本电脑和台式电脑的存储容量还要大。虽然能够存储数千张高分辨率照片和视频文件、安装数百个应用程序并随身携带大量音乐库以供离线收听固然很棒&#xff0c;但在一个地方拥有如此多的数据可能会带来毁灭性的后…

LNOI省选祭录

写在前面 大概率爆零 你说得对&#xff0c;但是「辽宁省2024联合省选」是一款由「中国计算机学会」推出的一款「开放世界冒险游戏」&#xff0c;游戏发生在一个被称作「大连大学」的幻想世界&#xff0c;在这里&#xff0c;被神选中的人将被授予「xor魔法手杖」&#xff0c;引…

#WEB前端(浮动与定位)

1.实验&#xff1a; 2.IDE&#xff1a;VSCODE 3.记录&#xff1a; float、position 没有应用浮动前 应用左浮动和右浮动后 应用定位 4.代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><me…

matplotlib直方图

matplotlib直方图 假设你获取了250部电影的时长(列表a中), 希望统计出这些电影时长的分布状态(比如时长为100分钟到120分钟电影的数量, 出现的频率)等信息, 你应该如何呈现这些数据? from matplotlib import pyplot as plt a[131, 98, 125, 131, 124, 139, 131, 117, 128, …

linux逻辑卷管理

一.物理卷&#xff0c;逻辑卷&#xff0c;卷组的关系 二.实验题目 1.业务需要&#xff0c;新增5G硬盘&#xff0c;先对第一块磁盘分区&#xff0c;大小为4G&#xff0c;现在进行逻辑卷划分&#xff0c;卷组名为myvg,逻辑卷名为LV1&#xff0c;大小为2G 2.格式化逻辑卷LV1&#…

【论文阅读】多传感器SLAM数据集

一、M2DGR 该数据集主要针对的是地面机器人&#xff0c;文章正文提到&#xff0c;现在许多机器人在进行定位时&#xff0c;其视角以及移动速度与车或者无人机有着较大的差异&#xff0c;这一差异导致在地面机器人完成SLAM任务时并不能直接套用类似的数据集。针对这一问题该团队…

附加Numpy数组

参考&#xff1a;Append Numpy Array 引言 在数据科学和机器学习领域&#xff0c;处理大规模数据集是一项重要且常见的任务。为了高效地处理数据&#xff0c;numpy是一个非常强大的Python库。本文将详细介绍numpy中的一个重要操作&#xff0c;即如何附加&#xff08;append&a…

【网站项目】308学生档案管理系统

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

【大数据Hive】hive 多字段分隔符使用详解

目录 一、前言 二、hive默认分隔符规则以及限制 2.1 正常示例&#xff1a;单字节分隔符数据加载示例 2.2 特殊格式的文本数据&#xff0c;分隔符为特殊字符 2.2.1 文本数据的字段中包含了分隔符 三、突破默认限制规则约束 3.1 数据加载不匹配情况 1 3.2 数据加载不匹配…