题目描述

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

输入输出格式

输入格式:

第一行两个数n,m。

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

输出格式:

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

输入输出样例

输入样例#1: 复制

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

  1. 0
  2. 7
  3. 7
  4. 1
  5. 1
  6. 3

说明

【数据规模】

m≤n≤2000000

ai​≤3×107

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

刚一看题

觉得这题特水

难道不是简单的ST表吗

于是自信满满的写了

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

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

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

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

然而这还不是最关键的

最关键的是

这次mle掉了

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

那么肯定说明

st表并不是这道题的正解

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

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

  1. #include<cstdio>
  2. #include<iostream>
  3. using namespace std;
  4.  
  5. int n,m;
  6. int d[][];
  7.  
  8. void RMQ()
  9. {
  10. for(int j = ;(<<j)<=n;j++)
  11. for(int i = ;i+(<<j)-<n;i++)
  12. d[i][j] = min(d[i][j-],d[i+(<<(j-))][j-]);
  13. }
  14.  
  15. void fid(int l,int r)
  16. {
  17. int k = ;
  18. while(<<(k+) <= r-l+)
  19. {
  20. k++;
  21. }
  22. printf("%d\n",min(d[l][k],d[r-(<<k)+][k]));
  23. }
  24.  
  25. int main()
  26. {
  27. scanf("%d%d",&n,&m);
  28. for(int i = ;i < n;i++)
  29. scanf("%d",&d[i][]);
  30. RMQ();
  31. printf("0\n");
  32. int ans = ;
  33. for(int i = ;i <= m;i++)
  34. fid(,i-);
  35. for(int i = m+;i < n;i++)
  36. fid(i-m,i-);
  37. return ;
  38. }

所以去学习了!!!

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

而正解是

单调队列

线性时间复杂度

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int maxn=;
  4. struct node{
  5. int v,id;
  6. }a[maxn];
  7. int ans[maxn];
  8. int n,m;
  9. deque<node> dq;
  10. int main()
  11. {
  12. scanf("%d%d",&n,&m);
  13. for(int i=;i<n;i++)
  14. {
  15. scanf("%d",&a[i].v);
  16. a[i].id=i;
  17. }
  18. ans[]=;
  19. for(int i=;i<n;i++)
  20. {
  21. //队首是价值最高的,队尾是最年轻的
  22. while(!dq.empty() && dq.back().v>=a[i-].v)
  23. dq.pop_back(); //比新元素老,价值还不如新元素的,一律弹掉
  24. dq.push_back(a[i-]);
  25. while(dq.front().id<i-m)
  26. dq.pop_front(); //不管价值如何,老死的一律弹掉
  27. ans[i]=dq.front().v; //front()就是最小元素值
  28. }
  29. for(int i=;i<n;i++)
  30. printf("%d\n",ans[i]);
  31. return ;
  32. }

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. Duplicate entry '0' for key 'PRIMARY'

    一般使用ORM时,提交新增实体时, mysql会出现此错误:Duplicate entry '0' for key 'PRIMARY' 原因是插入语句,未提供主键的值,且主键是非自增长的. 解决办法是 ...

  2. Python 标准类库-日期类型之datetime模块

    标准类库-日期类型之datetime模块    by:授客 QQ:1033553122 可用类型 3 实践出真知 4 timedelta对象 4 class datetime.timedelta(da ...

  3. WebStorm File Watchers配置将.less文件编译后的.css输出至指定目录

    Arguments:其实是命令行输入“lessc file.less file.css”后者指定路径 Output Paths to refresh:刷新changed后.css文件

  4. Android--使用JobService实现进程保活

    进程保活一直是广大APP开发者所希望的,因为进程活着我们就可以操作很多事情(推送,数据同步等等),但是google大大是不允许这样做的(优化),所以我们要另辟蹊径. 先来看看android中有几种进程 ...

  5. (后台)jxl.read.biff.BiffException: Unable to recognize OLE stream

    在excel中打开,另存成xls就可以.

  6. Spark算子代码实践

    package com.dingxin.datainit import org.apache.log4j.{Level, Logger} import org.apache.spark.sql.Spa ...

  7. 项目初始化mysql建库和授权

    创建数据库和授权 mysql -e "create database DATABASE DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_gen ...

  8. GIT基本命令介绍

    1.git remote git remote -v| --verbose 查看仓库详细信息 git remote add <name> <url> 关联远程库.如果你本地新建 ...

  9. SQL语句计算距离今天生日还差几天

    转载于:http://www.w3dev.cn/article/20110125/sql-compute-birthdate-now-days.aspx SQL语句计算距离生日还差几天原理很简单,将要 ...

  10. c/c++ 线性表之单向链表

    c/c++ 线性表之单向链表 线性表之单向链表 不是存放在连续的内存空间,链表中的每个节点的next都指向下一个节点,最后一个节点的下一个节点是NULL. 真实的第一个节点是头节点,头节点不存放数据, ...