思路:将查询区间按右节点的升序排列,然后插入第i个数的时候,若nun[i]+1已经插入,那么就update(pre[num[i]+1],-1);pre[]表示的是该数的位置。同样若

num[i]-1存在就update(pre[num[i]-1],-1);因为他么与num[i]属于一组,故只需一个存在就行。当查询的右边界r等于i时,只需对其左边界求和就行,Sum(qt[j].l)。

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#define Maxn 100010
#define lowbit(x) (x&(-x))
using namespace std;
int C[Maxn],pre[Maxn],n,ans[Maxn];
struct QT{
int l,r,i;
int operator <(const QT &temp) const
{
return r<temp.r;
}
}qt[Maxn];
int Sum(int pos)
{
int sum=;
while(pos<=n)//求和与更新反向的树状数组
{
sum+=C[pos];
pos+=lowbit(pos);
}
return sum;
}
void update(int pos,int val)
{
while(pos)
{
C[pos]+=val;
pos-=lowbit(pos);
}
}
int main()
{
int t,m,i,j,num[Maxn];
scanf("%d",&t);
while(t--)
{
memset(C,,sizeof(C));
memset(pre,,sizeof(pre));
scanf("%d%d",&n,&m);
for(i=;i<=n;i++)
scanf("%d",num+i),pre[num[i]]=i;
for(i=;i<=m;i++)
{
scanf("%d%d",&qt[i].l,&qt[i].r);
qt[i].i=i;
}
sort(qt+,qt++m);
j=;
for(i=;i<=n;i++)
{
if(j>m)
break;
if(num[i]<n&&pre[num[i]+]<i)
update(pre[num[i]+],-);
if(num[i]>&&pre[num[i]-]<i)
update(pre[num[i]-],-);
update(i,);
while(qt[j].r==i&&j<=m)
{
ans[qt[j].i]=Sum(qt[j].l);
j++;
}
}
for(i=;i<=m;i++)
printf("%d\n",ans[i]);
}
return ;
}

最新文章

  1. 数据可视化-EChart2.0.0使用中遇到的2个问题
  2. ps -C nginx --no-header |wc -l
  3. 接口测试之HttpClient
  4. [ACM_数学] LA 3708 Graveyard [墓地雕塑 圈上新加点 找规律]
  5. Javascript系列: Google Chrome调试js代码(zz)
  6. java.lang.VerifyError异常
  7. nova分析(2)—— nova-all
  8. 手机端overflow scroll卡顿的情况
  9. minicom installation and configuration on ubuntu
  10. WinForm简单多国语言实现
  11. JQuery的二维码插件
  12. Objects
  13. 201521123026《Java程序设计》第8周学习总结
  14. CSS样式命名整理(非原创)
  15. [CF 666E] Forensic Examination
  16. django中怎么使用自定义管理后台xadmin
  17. hasattr() getattr() setattr() 函数使用方法
  18. mysql排序数据
  19. jquery 如何获取有多个class名的元素
  20. cocos2dx 2.x 粒子渲染时有黑色粒BUG

热门文章

  1. Hibernate、Mybatis 通过数据库表反向生成java类和配置
  2. 获取iOS设备信息(内存/电量/容量/型号/IP地址/当前WIFI名称)
  3. Spring入门(10)-Spring JDBC
  4. Egret的VS环境搭配
  5. SQLserver锁和事务隔离级别的比较与使用(转)
  6. SQL 错误1418
  7. OpenNebula 创建虚拟机失败(未解决)
  8. mysql的top n查询
  9. flash 入门课知识小结
  10. Android之自定义AlertDialog无法监听控件