[HDOJ5289]Assignment(RMQ,二分)

时间:2022-09-01 18:24:33

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5289

题意:求满足区间内最大值和最小值差为k的区间个数。

预处理出区间的最值,枚举左端点,根据最值的单调性二分枚举右端点,使得找到最右侧max-min<k,区间数为[i,...hi]的个数,即hi-i+1个。

 #include <bits/stdc++.h>
using namespace std; typedef long long LL;
typedef pair<int, int> pii;
const int maxn = ;
int dp[maxn][][];
int a[maxn];
int n, k; void st(int* a, int* b, int n) {
for(int i = ; i <= n; i++) dp[i][][] = b[i], dp[i][][] = a[i];
for(int j = ; ( << j) - <= n; j++) {
for(int i = ; i + ( << j) - <= n; i++) {
dp[i][j][] = min(dp[i][j-][], dp[i+(<<(j-))][j-][]);
dp[i][j][] = max(dp[i][j-][], dp[i+(<<(j-))][j-][]);
}
}
} pii query(int l, int r) {
int k = int(log(r-l+) / log(2.0));
return pii(min(dp[l][k][], dp[r-(<<k)+][k][]), max(dp[l][k][], dp[r-(<<k)+][k][]));
} int main() {
// freopen("in", "r", stdin);
int T;
scanf("%d", &T);
while(T--) {
scanf("%d%d",&n,&k);
for(int i = ; i <= n; i++) scanf("%d", &a[i]);
st(a, a, n);
LL ret = ;
for(int i = ; i <= n; i++) {
int lo = i, hi = n;
while(lo <= hi) {
int mid = (lo + hi) >> ;
pii q = query(i, mid);
int minn = q.first, maxx = q.second;
if(maxx - minn < k) lo = mid + ;
else hi = mid - ;
}
ret += (hi - i + );
}
printf("%I64d\n", ret);
}
return ;
}

[HDOJ5289]Assignment(RMQ,二分)的更多相关文章

  1. HDU - 5289 Assignment &lpar;RMQ&plus;二分&rpar;&lpar;单调队列&rpar;

    题目链接: Assignment  题意: 给出一个数列,问其中存在多少连续子序列,使得子序列的最大值-最小值<k. 题解: RMQ先处理出每个区间的最大值和最小值(复杂度为:n×logn),相 ...

  2. hdoj5289【RMQ&plus;二分】【未完待续】

    思路: 对当前值查找最近满足位置: 利用RMQ求出区间最大最小值,再枚举右端点,二分区间找到满足要求的最大区间累加

  3. HDU 5089 Assignment(rmq&plus;二分 或 单调队列)

    Assignment Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total ...

  4. hdu 5289 Assignment(2015多校第一场第2题)RMQ&plus;二分(或者multiset模拟过程)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5289 题意:给你n个数和k,求有多少的区间使得区间内部任意两个数的差值小于k,输出符合要求的区间个数 ...

  5. &ast;HDU3486 RMQ&plus;二分

    Interviewe Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  6. hdu 3486 Interviewe &lpar;RMQ&plus;二分&rpar;

    Interviewe Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  7. 【bzoj2500】幸福的道路 树形dp&plus;倍增RMQ&plus;二分

    原文地址:http://www.cnblogs.com/GXZlegend/p/6825389.html 题目描述 小T与小L终于决定走在一起,他们不想浪费在一起的每一分每一秒,所以他们决定每天早上一 ...

  8. 玲珑杯 Round 19 B Buildings (RMQ &plus; 二分)

    DESCRIPTION There are nn buildings lined up, and the height of the ii-th house is hihi. An inteval [ ...

  9. HDU - 5289:Assignment(单调队列&vert;&vert;二分&plus;RMQ&vert;&vert;二分&plus;线段树)

    Tom owns a company and he is the boss. There are n staffs which are numbered from 1 to n in this com ...

随机推荐

  1. 【转】为什么我们都理解错了HTTP中GET与POST的区别

    GET和POST是HTTP请求的两种基本方法,要说它们的区别,接触过WEB开发的人都能说出一二. 最直观的区别就是GET把参数包含在URL中,POST通过request body传递参数. 你可能自己 ...

  2. &period;NET轻量级任务任务管理类

    概述 最近做项目总是遇到服务跑批等需求,一直想写个任务管理的DLL,现在整理了一下思路,编写了一个DLL类库,使用方便.只要调用的子类继承服务基类便可以实现任务的整体调度.先看看页面效果: 使用方式 ...

  3. JQuery实现页面刷新滚动条自动滚动到特定位置

    var cotentOffset = $('#6f').offset(); $('.info_box').animate({ scrollLeft: cotentOffset.left }, ); 原 ...

  4. Java String类型数据的字节长度

    问题描述: 向Oracle数据库中一varchar2(64)类型字段中插入一条String类型数据,程序使用String.length()来进行数据的长度校验,如果数据是纯英文,没有问题,但是如果数据 ...

  5. VS2010 调试不会命中当前断点

    方法1.直接把整个文件格式化了一次,断点就可以用了Ctrl + A全选菜单:编辑-〉高级-〉设置选定内容的格式 (Ctrl+K, Ctrl+F)通过比较文件发现是由于制表符Tab(0x09)引起的,原 ...

  6. JS拖拽原理

    实现拖拽效果主要跟鼠标的三个事件有关: onmousedown : 选择要拖拽的元素 onmousemove : 移动元素 onmouseup : 释放元素 三个事件的关系: obj.onmoused ...

  7. 2014&period;9&period;16HTML表单CSS

    (一)表格 合并单元格(少用) (合并列) 1.先选中要合并的2个或多个单元格,然后点击以下图标 代码:<td colspan="2"> </td> 2.设 ...

  8. &lbrack;Android&rsqb; &quot&semi;Failed to find Java version for &&num;39&semi;C&colon;&bsol;Windows&bsol;system32&bsol;java&period;exe&quot&semi;

    Impossible to install SDK r17 on win 7 x64 "Failed to find Java version for 'C:\Windows\system3 ...

  9. python小趣味&lowbar;520绘制一个心形&period;

    从某个公众号上看到的. 跑了一下, 居然可以成功运行. 有心的话可以研究下代码. 利用了turtle模块 #!/usr/bin/env python # coding:utf-8 import tur ...

  10. 基于nodemailer使用阿里云企业邮箱发送邮件(526错误的解决)

    在虽然日常生活中,QQ,微信等即时聊天工具几乎主导了人们的生活,但是邮件依然是现代生活不可缺少的一部分.这篇文章主要讲述使用node.js 中的nodemail模块操作阿里云的企业邮箱发送邮件 (52 ...