P9905 [COCI 2023/2024 #1] AN2DL 题解

2024-03-03 15:28
文章标签 2023 2024 题解 coci p9905 an2dl

本文主要是介绍P9905 [COCI 2023/2024 #1] AN2DL 题解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

思路

首先考虑暴力算法,枚举每一个右端点,再遍历求最大值,枚举的时间复杂度为 O ( n 2 ) O(n^2) O(n2),遍历复杂度同样 O ( n 2 ) O(n^2) O(n2)。显然,在 n = 3000 n=3000 n=3000 时无法通过,考虑更优解法。

大眼观察,发现这道题和 P1886 滑动窗口 /【模板】单调队列 是几乎一样的;也就是把一维单调队列变成了二维的单调队列。

当然,也可以理解成多个窗口在二维矩阵上面滑动;也就是一个 r × s r\times s r×s 的滑动窗口。

分析发现,这种算法是可以通过的,我们不妨分步解决,跑两次单调队列就可以完美解决问题!

操作流程:

n × m n\times m n×m 的矩阵每行都跑一次单调队列。

跑完后可以发现形成了一个 n × ( m − s + 1 ) n\times (m-s+1) n×(ms+1) 的矩阵 A A A,根据题意,不难发现, A i , j = max ⁡ j ≤ y ≤ ( j + s − 1 ) × C i , y A_{i,j}= \max\limits_{j\le y \le (j+s-1)}^{}\times C_{i,y} Ai,j=jy(j+s1)max×Ci,y(设 C C C 为题目输入的矩阵)

A A A 矩阵每列都跑一次单调队列(这样就形成了一个二维的单调队列结果)。

跑完后可以发现形成了一个 ( n − r + 1 ) × ( m − s + 1 ) (n-r+1)\times (m-s+1) (nr+1)×(ms+1) 的矩阵 B B B,根据题意,不难发现, B i , j = max ⁡ i ≤ x ≤ ( i + r − 1 ) × A x , y B_{i,j}= \max\limits_{i\le x \le (i+r-1)}^{}\times A_{x,y} Bi,j=ix(i+r1)max×Ax,y

此时的 B B B 矩阵就是所期望的啦!

代码:

_zuoqingyuan的代码基础上优化了码风,并增加了细节注释。

#include <bits/stdc++.h>
using namespace std;
int a[4005][4005], n, m, r, s; // a表示原始矩阵,n和m表示矩阵的行列数,r和s表示滑动窗口的大小。
vector <int> v1[4005], v2[4005]; // v1和v2用来存储中间结果和最终结果。
deque <int> q; // 双端队列用来维护滑动窗口。int main() {ios :: sync_with_stdio(false); // 禁用cin和cout的同步,提高I/O效率。cin >> n >> m; // 输入矩阵的行和列。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 ++) {v1[i].push_back(0); // 初始化v1的每一行。for (int j = 1; j <= m; j ++) {while (q.size() && q.front() <= j - s) q.pop_front(); // 若队列头部的元素已不在窗口内,弹出。while (q.size() && a[i][q.back()] < a[i][j]) q.pop_back(); // 若当前元素大于队尾元素,弹出队尾,维持队列单调递减。q.push_back(j); // 将当前列加入队列。if (j >= s) v1[i].push_back(a[i][q.front()]); // 若已到窗口大小,加入v1中。}q.clear(); // 清空队列为下一行做准备。}m = m - s + 1; // 更新列的有效长度。for (int i = 1; i <= m; i ++) {v2[i].push_back(0); // 初始化v2的每一列。for (int j = 1; j <= n; j ++) {while (q.size() && q.front() <= j - r) q.pop_front(); // 类似上面的操作,但是这次是行。while (q.size() && v1[q.back()][i] < v1[j][i]) q.pop_back(); // 维持队列单调递减。q.push_back(j); // 将当前行加入队列。if (j >= r) v2[i].push_back(v1[q.front()][i]); // 若已到窗口大小,加入v2中。}q.clear(); // 清空队列为下一列做准备。}n = n - r + 1; // 更新行的有效长度。// 输出最终结果。for (int i = 1; i <= n; i ++) {for (int j = 1; j <= m; j ++) cout << v2[j][i] << endl;cout << endl;}return 0;
}

这篇关于P9905 [COCI 2023/2024 #1] AN2DL 题解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/770040

相关文章

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

2024网安周今日开幕,亚信安全亮相30城

2024年国家网络安全宣传周今天在广州拉开帷幕。今年网安周继续以“网络安全为人民,网络安全靠人民”为主题。2024年国家网络安全宣传周涵盖了1场开幕式、1场高峰论坛、5个重要活动、15场分论坛/座谈会/闭门会、6个主题日活动和网络安全“六进”活动。亚信安全出席2024年国家网络安全宣传周开幕式和主论坛,并将通过线下宣讲、创意科普、成果展示等多种形式,让广大民众看得懂、记得住安全知识,同时还

2024/9/8 c++ smart

1.通过自己编写的class来实现unique_ptr指针的功能 #include <iostream> using namespace std; template<class T> class unique_ptr { public:         //无参构造函数         unique_ptr();         //有参构造函数         unique_ptr(

论文翻译:arxiv-2024 Benchmark Data Contamination of Large Language Models: A Survey

Benchmark Data Contamination of Large Language Models: A Survey https://arxiv.org/abs/2406.04244 大规模语言模型的基准数据污染:一项综述 文章目录 大规模语言模型的基准数据污染:一项综述摘要1 引言 摘要 大规模语言模型(LLMs),如GPT-4、Claude-3和Gemini的快

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口