洛谷 P3512 [POI2010] PIL-Pilots

首先就是对于超时的做法进行展示,这个思路是最原始的思路,也就是用单调队列的板子,用了两次,然后求差值,差值满足条件我们就直接返回这个长度,然后和后面的循环的长度进行相比。

#include<iostream>
#include<stdio.h>
#include<cstring>
#include<cstdlib>
#include<cmath> 
#include<vector>
#include<algorithm>
#include<stack>
#include<queue>
#include<deque>
#include <iomanip>
#include<sstream>
#include<numeric>
#include<map>
#include<limits.h>
#include<unordered_map>
#include<set>
#define int long long
#define MAX 300100
#define inf 0x3f3f3f3f
#define _for(i,a,b) for(int i=a;i<(b);i++)
#define ALL(x) x.begin(),x.end()
using namespace std;
typedef pair<int, int> PII;
int n, m, k;
int counts=inf;
int dx[] = { 0,1,0,-1};
int dy[] = { 1,0,-1,0 };
int q[MAX];
int arr[MAX];
int b1[MAX];
int b2[MAX];
int maxs,mins=inf;
void get_max(int a[], int b[], int n, int qujian) {int front = 0;int rear = -1;for (int i = 0; i < n; i++) {if (front <= rear && qujian + q[front] <= i)front++;while (front <= rear && a[q[rear]] <= a[i])rear--;q[++rear] = i;if (i >= qujian - 1)b[i] = a[q[front]];}}
void get_min(int a[], int b[], int n, int k) {int front = 0;int rear = -1;for (int i = 0; i < n; i++) {if (front <= rear && q[front] + k <= i)  {front++;}while (front <= rear && a[q[rear]] >= a[i])rear--;q[++rear] = i;b[i] = a[q[front]];}
}
signed main() {ios::sync_with_stdio(false);cin.tie(NULL); cout.tie(NULL);cin >> k >> n;for (int i = 0; i < n; i++) {cin >> arr[i];}int res = 0;for (int i = n; i >= 1; i--) {memset(q, 0, sizeof q);memset(b1, 0, sizeof b1);memset(b2, 0, sizeof b2);get_max(arr, b1, n, i);memset(q, 0, sizeof q);get_min(arr, b2, n, i);for (int j = i - 1; j < n; j++) {if (b1[j] - b2[j] <= k) {res = max(res, i);break;}}}cout << res;return 0;
}

接下来进行优化时,其实就是对于枚举的时候用了二分而已,也就是复杂度从On2变成了Onlogn

上代码:

#include<iostream>
#include<stdio.h>
#include<cstring>
#include<cstdlib>
#include<cmath> 
#include<vector>
#include<algorithm>
#include<stack>
#include<queue>
#include<deque>
#include <iomanip>
#include<sstream>
#include<numeric>
#include<map>
#include<limits.h>
#include<unordered_map>
#include<set>
#define int long long
#define MAX 2000000
#define inf 0x3f3f3f3f
#define _for(i,a,b) for(int i=a;i<(b);i++)
#define ALL(x) x.begin(),x.end()
using namespace std;
typedef pair<int, int> PII;
int n, m, k;
int counts=inf;
int dx[] = { 0,1,0,-1};
int dy[] = { 1,0,-1,0 };
int q[MAX];
int arr[MAX];
int b[MAX];
int extra[MAX];
int maxs;
bool get_max(int a[], int b[],int b2[], int n, int qujian) {int front = 0;int rear = -1;for (int i = 0; i < n; i++) {if (front <= rear && qujian + q[front] <= i)front++;while (front <= rear && a[q[rear]] <= a[i])rear--;q[++rear] = i;if (i >= qujian - 1)b[i] = a[q[front]];}memset(q, 0, sizeof q);front = 0;rear = -1;for (int i = 0; i < n; i++) {if (front <= rear && qujian + q[front] <= i)front++;while (front <= rear && a[q[rear]] >= a[i])rear--;q[++rear] = i;if (i >= qujian - 1)b2[i] = a[q[front]];}for (int i = qujian - 1; i < n; i++) {if (b[i] - b2[i] <= k) {return true;}}return false;
}signed main() {ios::sync_with_stdio(false);cin.tie(NULL); cout.tie(NULL);cin >> k >> n;for (int i = 0; i < n; i++) {cin >> arr[i];}int l = 1;int r = n;while (l < r) {memset(b, 0, sizeof b);memset(extra, 0, sizeof extra);int mid = (l + r + 1) / 2;if (get_max(arr, b, extra, n, mid))l = mid;elser = mid - 1;}cout << l;return 0;
}

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

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

相关文章

《QT实用小工具·十八》高亮发光按钮控件

1、概述 源码放在文章末尾 该项目实现了高亮发光按钮控件 可设置文本&#xff0c;居中显示。可设置文本颜色。可设置外边框渐变颜色。可设置里边框渐变颜色。可设置背景色。可直接调用内置的设置 绿色、红色、黄色、黑色、蓝色 等公有槽函数。可设置是否在容器中可移动&#…

git应用场景(进阶)

Git场景运用-CSDN博客 专有名词 Workspace&#xff1a;工作区 Index / Stage&#xff1a;暂存区 Repository&#xff1a;仓库区&#xff08;或本地仓库&#xff09; Remote&#xff1a;远程仓库HEAD HEAD&#xff0c;指向当前分支最新提交点。所处分支变化&#xff0c;或产生新…

Open CASCADE学习|旋转变换

物体在三维空间中的旋转变换操作通常可以通过三种不同的方式来表示&#xff1a;矩阵&#xff08;Matrix&#xff09;、欧拉角&#xff08;Euler Angles&#xff09;和四元数&#xff08;Quaternion&#xff09;。下面详细解释这三种表示方法。 矩阵&#xff08;Matrix&#xf…

centos后台运行使用nohup命令

nohup ./my_script.sh & nohup命令运行后如何关闭 nohup 命令用于在用户注销系统后继续运行指定的命令。如果您想关闭使用 nohup 运行的进程&#xff0c;您可以使用 kill 命令。 首先&#xff0c;您需要找到 nohup 运行的进程的进程ID&#xff08;PID&#xff09;。可以使…

【云开发笔记No.21】如何建设中台

这里主要讨论一下中台的建设步骤和组织方法。 随着企业业务的快速发展和数字化转型的深入&#xff0c;中台建设成为众多企业追求高效运营和创新发展的关键一环。中台&#xff0c;作为一个集成了业务、数据和技术的共享服务平台&#xff0c;旨在实现资源的统一管理和高效复用。…

C++的并发世界(八)——lock_guard和unique_lock

1.lock_guard lock_guard是C的stl库中的一种互斥量封装嘞&#xff0c;用于保护共享数据&#xff0c;防止多个线程同时访问同一资源而导致的数据竞争问题。&#xff0c;其包括以下成员函数&#xff1a; 函数名作用lock尝试对互斥量进行加锁&#xff0c;如果当前互斥量已经被其他…

写JDBC遇到的问题

执行会出现以下错误信息 java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ? and loginPwd ? at line 1 at com.mysql.cj.jdbc.exceptions…

Unix Domain Sockets (UDS) 简介

Unix Domain Sockets (UDS) 是一种进程间通信&#xff08;IPC, Inter-Process Communication&#xff09;机制&#xff0c;特别适用于在同一台主机操作系统上运行的多个进程之间进行高效的数据交换。它是基于文件系统路径或者匿名内存区域创建的套接字&#xff08;socket&#…

图书管理系统

❤️❤️前言~&#x1f973;&#x1f389;&#x1f389;&#x1f389; hellohello~&#xff0c;大家好&#x1f495;&#x1f495;&#xff0c;这里是E绵绵呀✋✋ &#xff0c;如果觉得这篇文章还不错的话还请点赞❤️❤️收藏&#x1f49e; &#x1f49e; 关注&#x1f4a5;&a…

sqlalchemy中Datetime的创建时间-修改时间之default|server_default|onupdate

default vs. server_default 的区别 default 这个属性 &#xff0c;就是默认生成orm 对象,如果某个字段没有 传值&#xff0c;就使用default 值&#xff0c;然后写入到数据库中。 server_default 这个属性&#xff0c;要求是一个str, unicode 类型。 用来生成表结构的时候&am…

Vue - 你会在同一个元素上使用v-for和v-if吗

难度级别:初级及以上 提问概率:50% 在初学者看来,v-for和v-if同时使用是非常方便的,二者共同使用的常见场景有两种。例如有两个列表,分别用于渲染学生数据和老师数据,然后有两个单选按钮,用于切换当前页面中需要展示学生列表还是老师列…

鸿蒙HarmonyOS 与 Android 的NDK有什么不一样?

1. 序言 就像开发Android要用Android Studio一样&#xff0c;Android Studio&#xff08;简称AS&#xff09;其实是基于IDEAgradle插件android插件开发而来。 鸿蒙系统&#xff0c;你可以认为它和android有点像&#xff0c;但又是超越android的存在&#xff0c;除了手机&…

【洛谷题解】 P10337 [UESTCPC 2024] 操作序列

分析 首先&#xff0c;我们知道&#xff0c;当这 n n n 个数全部相等时&#xff0c; k k k 的最大值就是 n n n。 那如果不相等呢&#xff0c; k k k 就不可能为 n n n 得值了&#xff0c;因为每次他都要选择 k k k 个不同位置上的数乘上一个相同的数&#xff0c;把几个不…

nginx目录sites-enabled和sites-available介绍

模块简介&#xff1a; 在Nginx中&#xff0c;/etc/nginx/sites-enabled 目录和 /etc/nginx/sites-available 目录通常用于组织虚拟主机配置文件&#xff0c;这些文件描述了不同站点的设置&#xff0c;例如域名、目录结构等。 /etc/nginx/sites-available 目录&#xff1a;存放…

go-zero整合单机版Redis并实现增删改查

go-zero整合单机版Redis并实现增删改查 本教程基于go-zero微服务入门教程&#xff0c;项目工程结构同上一个教程。 go-zero微服务入门教程&#xff08;点击进入&#xff09; 本教程主要实现go-zero框架整合单机版Redis&#xff0c;并暴露接口实现对Redis数据的增删改查。 本…

Oracle容器镜像制作

对于 Oracle 数据库的容器镜像制作&#xff0c;oracle 官方提供了 Dockerfile 文件和制作脚本的&#xff08;https://github.com/oracle/docker-images&#xff09;。这里以 12c 为例看看怎么使用。 下载官方提供的 Dockerfile 文件和制作脚本 $ git clone https://github.com/…

笛卡尔树[天梯赛二叉树专项训练]

文章目录 题目描述思路AC代码 题目描述 输入样例1 6 8 27 5 1 9 40 -1 -1 10 20 0 3 12 21 -1 4 15 22 -1 -1 5 35 -1 -1 输出样例1 YES 输入样例2 6 8 27 5 1 9 40 -1 -1 10 20 0 3 12 11 -1 4 15 22 -1 -1 50 35 -1 -1 输出样例2 NO思路 见注释 AC代码 #include <bits/st…

【重学C语言】五、分支结构

【重学C语言】五、分支结构 三种结构分支结构if 语句示例 1&#xff1a;基本的 if 语句 if...else 语句示例 2&#xff1a;if...else 语句 嵌套 if示例 3&#xff1a;嵌套的 if 语句 if 语句与逻辑运算符示例 4&#xff1a;使用逻辑与&#xff08;&&&#xff09;示例 5…

搭建python编译环境

目录 1.安装依赖包 2.安装失败进行换源 3. 更新系统 通过C 语言调用 Python 代码&#xff0c;需要先安装 libpython3 的 dev 依赖库&#xff08;不同的 ubuntu 版本下&#xff0c; python 版本 可能会有差异&#xff0c; 比如ubuntu 22.04 里是 libpython3.10-dev &#xff09…

2024/4/1—力扣—最小高度树

代码实现&#xff1a; /*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/ struct TreeNode* buildTree(int *nums, int l, int r) {if (l > r) {return NULL; // 递归出口}struct…