hdu 5654 xiaoxin and his watermelon candy 树状数组维护区间唯一元组

时间:2022-09-27 15:39:52

题目链接

题意:序列长度为n(1<= n <= 200,000)的序列,有Q(<=200,000)次区间查询,问区间[l,r]中有多少个不同的连续递增的三元组。

思路:连续三元组->递推O(n)将第一次出现该三元组的下标记录到树状数组中,并且用一个Next[]来表示递推关系,即同一个三元组下一次出现的位置是Next[x];这很关键,在之后按照左边界处理时(有点像莫队算法),一直递推在l+1左侧重复出现的三元组,为了把该三元组推到出现在[l,r]或者[r+1,..]中,这样不重不漏。

使用map维护出现的id即可,题目很经典~~

#include<bits/stdc++.h>
using namespace std;
#define rep0(i,l,r) for(int i = (l);i < (r);i++)
#define rep1(i,l,r) for(int i = (l);i <= (r);i++)
#define rep_0(i,r,l) for(int i = (r);i > (l);i--)
#define rep_1(i,r,l) for(int i = (r);i >= (l);i--)
#define MS0(a) memset(a,0,sizeof(a))
#define MS1(a) memset(a,-1,sizeof(a))
#define MSi(a) memset(a,0x3f,sizeof(a))
#define inf 0x3f3f3f3f
#define lson l, m, rt << 1
#define rson m+1, r, rt << 1|1
typedef pair<int,int> PII;
#define A first
#define B second
#define MK make_pair
typedef __int64 ll;
typedef unsigned int uint;
template<typename T>
void read1(T &m)
{
T x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
m = x*f;
}
template<typename T>
void read2(T &a,T &b){read1(a);read1(b);}
template<typename T>
void read3(T &a,T &b,T &c){read1(a);read1(b);read1(c);}
template<typename T>
void out(T a)
{
if(a>) out(a/);
putchar(a%+'');
}
int T,kase = ,i,j,k,n,m,l,r;
#define N 200200
map<pair<PII,int>,int> mp;
int a[N],B[N],Next[N],x[N],y[N],o[N],ans[N];
bool cmp(int a,int b){return x[a] < x[b];}
#define lowbit(x) (x&(-x))
void update(int p,int d)
{
while(p <= n) B[p] += d,p += lowbit(p);
}
int query(int x)
{
int ans = ;
while(x) ans += B[x],x -= lowbit(x);
return ans;
}
int main()
{
//freopen("data.txt","r",stdin);
//freopen("out.txt","w",stdout);
read1(T);
while(T--){
mp.clear();
read1(n);
rep1(i,,n) B[i] = Next[i] = ;
rep1(i,,n) read1(a[i]);
rep1(i,,n){
if(a[i] >= a[i-] && a[i-] >= a[i-]){
int x = mp[MK(MK(a[i],a[i-]),a[i-])];
if(x == ) update(i,);
else Next[x] = i;//递推
mp[MK(MK(a[i],a[i-]),a[i-])] = i;
}
}
read1(m);
rep0(i,,m) read2(x[i],y[i]),o[i] = i;
sort(o,o+m,cmp);
int p = ;
rep0(i,,m){
int l = x[o[i]],r = y[o[i]];
while(p <= l+){
if(Next[p]) update(Next[p],);//递推到下一个~~
p++;
}
if(r > l + ) ans[o[i]] = query(r) - query(l+);
else ans[o[i]] = ;
}
rep0(i,,m){
printf("%d\n",ans[i]);
}
}
return ;
}

hdu 5654 xiaoxin and his watermelon candy 树状数组维护区间唯一元组的更多相关文章

  1. 2018中国大学生程序设计竞赛 - 网络选拔赛 1010 YJJ&&num;39&semi;s Salesman 【离散化&plus;树状数组维护区间最大值】

    题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6447 YJJ's Salesman Time Limit: 4000/2000 MS (Java/O ...

  2. bzoj 2819 Nim dfn序&plus;树状数组维护区间异或值

    题目大意 著名游戏设计师vfleaking,最近迷上了Nim.普通的Nim游戏为:两个人进行游戏,N堆石子,每回合可以取其中某一堆的任意多个,可以取完,但不可以不取.谁不能取谁输.这个游戏是有必胜策略 ...

  3. HDU 1754 I hate it 树状数组维护区间最大值

    Problem Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少.这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写 ...

  4. ACM-ICPC 2018 徐州赛区网络预赛 G&period; Trace【树状数组维护区间最大值】

    任意门:https://nanti.jisuanke.com/t/31459 There's a beach in the first quadrant. And from time to time, ...

  5. Playrix Codescapes Cup &lpar;Codeforces Round &num;413&comma; rated&comma; Div&period; 1 &plus; Div&period; 2&rpar; C&period; Fountains 【树状数组维护区间最大值】

    题目传送门:http://codeforces.com/contest/799/problem/C C. Fountains time limit per test 2 seconds memory ...

  6. 牛客练习赛52 B题【树状数组维护区间和&lbrace;查询区间和,如果区间元素重复出现则计数一次&rcub;】补题ing

    [题目] 查询区间和,如果区间元素重复出现则计数一次. 链接:https://ac.nowcoder.com/acm/contest/1084/B [题解] 将询问按r排序,维护每个数最后出现的位置, ...

  7. 牛客练习赛47 E&Tab;DongDong数颜色 (树状数组维护区间元素种类数)

    链接:https://ac.nowcoder.com/acm/contest/904/E 来源:牛客网 DongDong数颜色 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 5242 ...

  8. HDU 5654 xiaoxin and his watermelon candy 离线树状数组 区间不同数的个数

    xiaoxin and his watermelon candy 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5654 Description Du ...

  9. HDU 5654 xiaoxin and his watermelon candy 离线树状数组

    xiaoxin and his watermelon candy Problem Description During his six grade summer vacation, xiaoxin g ...

随机推荐

  1. 基于UUID生成短ID

    为什么需要短ID 数据库操作过程最常用到: 自增ID UUID 前者多数依赖Mysql的auto_increment,但数据移植麻烦. 如果是主从或主主,不同库里自增ID还可能不一致. 后者长度是个问 ...

  2. hive-安装MySQL&lpar;centos6&period;4&rpar;

    为安装hive做准备,以前装过无数次,在线的.tar包的,一直不用忘得差不多了. centos6.4 虚拟机 先看有没有装,有的话应该是自带的,卸载就可以了 命令分别是 然后在线安装,命令是 (-y是 ...

  3. 源码&lpar;05&rpar; -- java&period;util&period;AbstractCollection&lt&semi;E&gt&semi;

    java.util.AbstractCollection<E> 源码分析(JDK1.7) ------------------------------------------------- ...

  4. Windows提权与开启远程连接

    1.提权: 建立普通用户:net user 帐户 密码 /add 提权成管理员:net localgroup administrators 帐户 /add 更改用户密码:net user 帐户 密码 ...

  5. Linux下卸载Oracle 11g

    第一种方法: 使用oracle自带的runInstaller 卸载 [oracle@VM_0_14_centos deinstall]$ cd $ORACLE_HOME [oracle@VM_0_14 ...

  6. 神奇的thrust&colon;&colon;device&lowbar;vector与nvcc编译选项

    在C++的GPU库thrust中,有两种vector thrust::device_vector<int> D; //GPU使用的内存中的向量 thrust::host_vector&lt ...

  7. 微信WeUI常见页面模板

    购物车模板 就是popup弹层(css样式+js),还有slider滑动操作,还有增减的js 代码: <!DOCTYPE html> <html lang="zh-CN&q ...

  8. Spring Cloud&lpar;五&rpar;:熔断监控Hystrix Dashboard和Turbine

    Hystrix-dashboard是一款针对Hystrix进行实时监控的工具,通过Hystrix Dashboard我们可以在直观地看到各Hystrix Command的请求响应时间, 请求成功率等数 ...

  9. JavaScript的六种数据类型

      JavaScript数据类型有六种:number.string.boolean.null.undefined.object

  10. ActiveMQ基于JMS的pub&sol;sub传播机制

    原文地址:[ActiveMQ实战]基于JMS的pub/sub传播机制 发布订阅模型 就像订阅报纸,我们可以选择一份或者多份报纸.比如:北京日报.人民日报.这些报纸就相当于发布订阅模型中的topic.如 ...