题目描述

一个含有n项的数列(n<=2000000),求出每一项前的m个数到它这个区间内的最小值。若前面的数不足m项则从第1个数开始,若前面没有数则输出0。

输入输出格式

输入格式:

第一行两个数n,m。

第二行,n个正整数,为所给定的数列。

输出格式:

n行,第i行的一个数ai,为所求序列中第i个数前m个数的最小值。

输入输出样例

输入样例#1: 复制

6 2
7 8 1 4 3 2
输出样例#1: 复制

0
7
7
1
1
3

说明

【数据规模】

m≤n≤2000000

ai​≤3×107

---------------------------------------

刚一看题

觉得这题特水

难道不是简单的ST表吗

于是自信满满的写了

于是发生了不可思议的事情

这是本题的部分代码,黄色部分(好像看不太清),必须写上+1才能过样例!

而这个写上就不过,好像必须省略

然而,书上模板代码都是有+1的,这我就懵了

然而这还不是最关键的

最关键的是

这次mle掉了

我可是精心溜边走得数组大小啊

那么肯定说明

st表并不是这道题的正解

但是我还要放我的错误ST表的代码

这是错误的代码啊!!!!!

#include<cstdio>
#include<iostream>
using namespace std; int n,m;
int d[][]; void RMQ()
{
for(int j = ;(<<j)<=n;j++)
for(int i = ;i+(<<j)-<n;i++)
d[i][j] = min(d[i][j-],d[i+(<<(j-))][j-]);
} void fid(int l,int r)
{
int k = ;
while(<<(k+) <= r-l+)
{
k++;
}
printf("%d\n",min(d[l][k],d[r-(<<k)+][k]));
} int main()
{
scanf("%d%d",&n,&m);
for(int i = ;i < n;i++)
scanf("%d",&d[i][]);
RMQ();
printf("0\n");
int ans = ;
for(int i = ;i <= m;i++)
fid(,i-);
for(int i = m+;i < n;i++)
fid(i-m,i-);
return ;
}

所以去学习了!!!

----------------------------------------------------

而正解是

单调队列

线性时间复杂度

#include <bits/stdc++.h>
using namespace std;
const int maxn=;
struct node{
int v,id;
}a[maxn];
int ans[maxn];
int n,m;
deque<node> dq;
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<n;i++)
{
scanf("%d",&a[i].v);
a[i].id=i;
}
ans[]=;
for(int i=;i<n;i++)
{
//队首是价值最高的,队尾是最年轻的
while(!dq.empty() && dq.back().v>=a[i-].v)
dq.pop_back(); //比新元素老,价值还不如新元素的,一律弹掉
dq.push_back(a[i-]);
while(dq.front().id<i-m)
dq.pop_front(); //不管价值如何,老死的一律弹掉
ans[i]=dq.front().v; //front()就是最小元素值
}
for(int i=;i<n;i++)
printf("%d\n",ans[i]);
return ;
}

P1440 求m区间内的最小值--洛谷luogu的更多相关文章

  1. 洛谷 P1440 求m区间内的最小值

    传送门 思路 由于数据范围很大,所以使用单调队列,和滑动窗口这道题类似 首先第一个数输出\(0\),因为第一个数之前没有数 然后通过样例我们发现,最后一个数并没有派上什么用场,所以循环\(n-1\)轮 ...

  2. P1886 滑动窗口&&P1440 求m区间内的最小值

    声明:下面这两个题就不要暴力了,学一学单调队列吧 推荐博文:https://www.cnblogs.com/tham/p/8038828.html 单调队列入门题 P1440 求m区间内的最小值 题目 ...

  3. 【题解】P1440 求m区间内的最小值

    求m区间内的最小值 题目描述: 一个含有n项的数列(n<=2000000),求出每一项前的m个数到它这个区间内的最小值.若前面的数不足m项则从第1个数开始,若前面没有数则输出0. 分析: 读题之 ...

  4. 洛谷—— P1440 求m区间内的最小值

    https://www.luogu.org/problemnew/show/P1440 题目描述 一个含有n项的数列(n<=2000000),求出每一项前的m个数到它这个区间内的最小值.若前面的 ...

  5. luogu P1440 求m区间内的最小值

    题目描述 一个含有n项的数列(n<=2000000),求出每一项前的m个数到它这个区间内的最小值.若前面的数不足m项则从第1个数开始,若前面没有数则输出0. 输入输出格式 输入格式: 第一行两个 ...

  6. P1440 求m区间内的最小值

    题目描述 一个含有n项的数列(n<=2000000),求出每一项前的m个数到它这个区间内的最小值.若前面的数不足m项则从第1个数开始,若前面没有数则输出0. 输入输出格式 输入格式: 第一行两个 ...

  7. [洛谷P1440]求m区间内的最小值

    题目大意:给你n个数,求出每个数前m位的最小值 题解:单调队列,用一个可以双向弹出的队列来存一串数,满足里面的数具有单调性,我们可以假设它是单调递增的,即求最小的数.那么可以把要插入的这个数与队尾元素 ...

  8. 洛谷 P1440 求m区间内的最小值(单调队列)

    题目链接 https://www.luogu.org/problemnew/show/P1440 显然是一道单调队列题目…… 解题思路 对于单调队列不明白的请看这一篇博客:https://www.cn ...

  9. 求m区间内的最小值

    洛谷P1440 求m区间内的最小值 ............................................................................... 以上 ...

随机推荐

  1. 苹果8plus怎么录屏视频

    现在越来越多的手机控,不管在什么地方,什么时候,都是低头看手机的居多,因为手机信息量太大了,一部手机就可以了解最新咨询,但是作为苹果8plus怎么录制手机屏幕,你们知道吗?今天就和大家一起分享苹果8p ...

  2. web-worker 的使用

    JavaScript采用的是单线程模式,它每次也只能执行一个事件,所以它在加载大量的事件的时候会比较慢. 而web-worker的作用就是给JavaScript提供一个多线程的模式. 注意的是 web ...

  3. 章节三、5-Getters-Setters和this关键字part01

    我们新建第一个Car类: package introduction; public class Car { //颜色 private String color; //生成商 private Strin ...

  4. CentOS 7.x默认没有ifconfig?!

    刚装了CentOS 7.0,安装界面非常漂亮,装完后发现没有ifconfig命令.yum install net-tools后出现. 有两个可能,一个是mini版本的原因,二一个可能我在安装过程中配置 ...

  5. 编程经验点滴----巧妙解决 Oracle NClob 读写问题

    最近一个新项目中,尝试在 Oracle 数据库中使用 NCLOB 来保存大的 xml 字符串. 在代码自动生成工具(通过 JDBC 驱动程序,读数据库表结构,自动生成对应的 java 代码,包含增加. ...

  6. python 画个小猪佩奇

    不知道大家小时候有没有学习过logo语言,就是操纵一只小王八,来画各种图案.博主小学微机课就学习了这个,最近发现python的turtle包就是logo语言,所以画个小猪佩奇和大家分享. 代码来自知乎 ...

  7. LeetCode题解之Keys and Rooms

    1.题目描述 2.问题分析 使用深度优先遍历 3.代码 bool canVisitAllRooms(vector<vector<int>>& rooms) { int ...

  8. 如何获取Azure AD tenant的tenant Id?

          一般情况下,Azure AD用户知道自己tenant域名,因为域名是账户的后缀,例如:contoso.onMicrosoft.com.如果你还不了解什么是Azure AD tenant,可 ...

  9. Android 自定义ListView单击事件失效

    因为自带的listView不能满足项目需求,通过实现自己的Adapter去继承ArrayAdapter 来实现自定义ListView的Item项目. 出现点击ListView的每一项都不会执行setO ...

  10. 教你用Python Jupyter Notebook 制作代码分享 PPT

    PPT 是个强大的工具,但是笔者的 PPT 制作技术不咋地,所以之前的分享习惯使用 Jupyter Notebook + RISE,这样使用简单的 markdown 格式加上代码就足够做一次代码分享了 ...