kb-07-RMQ线段树--07(动态规划)
RMQ是一类解决区间最值查询的算法的通称;、一共有四类;在代码中有说明;
下面是ST算法,就是动态规划做法;
/*
RMQ算法、
RMQ是一个通称,专指区间求最值的算法;
分为:暴力,线段树,动态规划(ST),RMQ标准算法;四种
这一题用普通的线段树也是可以做的,维护区间最大值和区间最小值然后查询区间最值然后做差就行了;
这里用的是动态规划法就是ST;
*/
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int n,q;
int a[]={},d[][]={},dd[][]={};
void RMQ_inti_min()
{
for(int i=;i<n;i++)
{
d[i][]=a[i];
}
for(int i=;(<<i)<=n;i++)//控制的是第二维;
{
for(int j=;j+(<<i)-<n;j++)
{
d[j][i]=min(d[j][i-],d[j+(<<(i-))][i-]);
}
}
}
void RMQ_inti_max()
{
for(int i=;i<n;i++)
{
dd[i][]=a[i];
}
for(int i=;(<<i)<=n;i++)//控制的是第二维;
{
for(int j=;j+(<<i)-<n;j++)
{
dd[j][i]=max(dd[j][i-],dd[j+(<<(i-))][i-]);
}
}
}
int RMQ_min(int l,int r)
{
int k=;
while((<<(k+))<=r-l+)
k++;
return min(d[l][k],d[r-(<<k)+][k]);
}
int RMQ_max(int l,int r)
{
int k=;
while((<<(k+))<=r-l+)
k++;
return max(dd[l][k],dd[r-(<<k)+][k]);
}
int main()
{
while(scanf("%d%d",&n,&q)!=EOF)
{
memset(a,,sizeof(a));
memset(d,,sizeof(d));
memset(dd,,sizeof(dd));
for(int i=;i<n;i++)
{
scanf("%d",&a[i]);
}
RMQ_inti_min();
RMQ_inti_max();
for(int i=;i<q;i++)
{
int l,r;
scanf("%d%d",&l,&r);
int max=RMQ_max(l-,r-);
int min=RMQ_min(l-,r-);
printf("%d\n",max-min);
}
}
return ;
}
kb-07-RMQ线段树--07(动态规划)的更多相关文章
- NBU 2475 Survivors(RMQ线段树)
NBU 2475Survivors 题目链接:http://acm.nbu.edu.cn/v1.0/Problems/Problem.php?pid=2475 题意:给定n个人,每个人有strengt ...
- 【agc023E】Inversions(线段树,动态规划)
[agc023E]Inversions(线段树,动态规划) 题面 AT 给定\(a_i\),求所有满足\(p_i\le a_i\)的排列\(p\)的逆序对数之和. 题解 首先如何计算排列\(p\)的个 ...
- ACM学习历程—HDU5696 区间的价值(分治 && RMQ && 线段树 && 动态规划)
http://acm.hdu.edu.cn/showproblem.php?pid=5696 这是这次百度之星初赛2B的第一题,但是由于正好打省赛,于是便错过了.加上2A的时候差了一题,当时有思路,但 ...
- UESTC 764 失落的圣诞节 --RMQ/线段树
题意:n种物品,每种物品对不同的人都有不同的价值,有三个人选,第一个为普通学生,第二个是集,第三个是祈,集和祈可以选一样的,并且还会获得加分,集和祈选的普通学生都不能选,问三个人怎样选才能使总分最高. ...
- [RMQ] [线段树] POJ 3368 Frequent Values
一句话,多次查询区间的众数的次数 注意多组数据!!!! RMQ方法: 预处理 i 及其之前相同的数的个数 再倒着预处理出 i 到不是与 a[i] 相等的位置之前的一个位置, 查询时分成相同的一段和不同 ...
- VJ16216/RMQ/线段树单点更新
题目链接 /* 单点更新,用RMQ维护最大值,add对c[i]修改,或加,或减. 求[l,r]的和,用sum(r)-sum(l-1).即可. */ #include<cmath> #inc ...
- 51Nod.1766.树上最远点对(树的直径 RMQ 线段树/ST表)
题目链接 \(Description\) 给定一棵树.每次询问给定\(a\sim b,c\sim d\)两个下标区间,从这两个区间中各取一个点,使得这两个点距离最远.输出最远距离. \(n,q\leq ...
- lca 欧拉序+rmq(st) 欧拉序+rmq(线段树) 离线dfs 倍增
https://www.luogu.org/problemnew/show/P3379 1.欧拉序+rmq(st) /* 在这里,对于一个数,选择最左边的 选择任意一个都可以,[left_index, ...
- poj2763(lca / RMQ + 线段树)
题目链接: http://poj.org/problem?id=2763 题意: 第一行输入 n, q, s 分别为树的顶点个数, 询问/修改个数, 初始位置. 接下来 n - 1 行形如 x, y, ...
随机推荐
- java入门第一章——java开发入门
习题解答 一.填空题 (p2)1.java的三个技术平台分别是(java SE.java EE.java ME)(标准.企业.小型) (p3)2.java程序的运行环境简称为(JRE)(开发环境-JD ...
- js 获取当前年月日时分秒星期
$("#aa").click(function () { var date = new Date(); this.year = date.getFullYear(); this.m ...
- Windows环境下使用Apache+mod
1.安装Python和Apache. 2.安装mod_wsgi后获得wsgi.so,并将wsgi.so放到Apache的modules文件夹下. 3.安装webpy. 4.打开httpd.conf(在 ...
- 剑指offer55 字符流中第一个不重复的字符(最典型错误)
典型并且基础的错误: class Solution { public: //Insert one char from stringstream void Insert(char ch) { ) res ...
- Centos7.3 安装devstack stein版本
1. 系统准备 # 关闭防火墙 systemctl stop firewalld systemctl disable firewalld # 关闭selinux setenforce 0 sed -i ...
- Oracle11g 数据库的导入导出
导出: 全部: exp imagesys/imagesys@orcl file=/icms/20170116.dmp full=y 用户: exp imagesys/imagesys @orcl fi ...
- 转 Spring Security 简介
https://blog.csdn.net/xlecho/article/details/80026527 Spring Security 简介 2018年04月21日 09:53:02 阅读数:13 ...
- MySQL 查询优化之 Block Nested-Loop 与 Batched Key Access Joins
MySQL 查询优化之 Block Nested-Loop 与 Batched Key Access Joins 在MySQL中,可以使用批量密钥访问(BKA)连接算法,该算法使用对连接表的索引访问和 ...
- k8s搭建WebUI--Dashborad管理界面
k8s的webUI管理界面可以更好更直观更便捷的让我们去管理我们的k8s集群. 我们知道,由于某些原因我们无法直接拉取dashboard的镜像,但是国内有些人已经将镜像下载到dockerhub中可以给 ...
- phpstudy2016+phpstorm2017-3+xdebug+chrome
1. 勾选Xdebug 后 phpstudy 会自动重启服务 [XDebug] xdebug.profiler_output_dir="D:\phpStudy\tmp\xdebug" ...