HDU 3333 树状数组离线查询
题目大意:
询问区间内不同种类的数的数值之和
这里逐个添加最后在线查询,会因为相同的数在区间内导致冲突
我们总是希望之后添加的数不会影响前面,那么我们就在添加到第i个数的时候,把所有在1~i 的区间的询问全部处理完成即可
对于之前的冲突,我们可以不断记录上一次冲突的位置,给当前的前缀和添加一个当前的val
对于上一次之前的前缀和要减去那个val就不会产生冲突了(之所以离线也是因为这个地方,如果后面的数添加完成,那么之前可能减去那个位置的数就导致区间查询出错)
所以将询问区间优先右排序就行了
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream>
#include <map>
using namespace std; #define LL long long
#define lowbit(x) x&(-x)
#define M 100010
#define N 30005
char s[];
int n , m , a[N];
LL sum[N] ;
map<int ,int> mp; struct Query{
int l , r , id;
bool operator<(const Query &m) const{
return r<m.r || (r==m.r&&l<m.l);
}
}qu[M]; LL rec[M]; void add(int x , int v)
{
while(x<=n){
sum[x] = sum[x]+v ;
x+=lowbit(x);
}
} LL query(int x){
LL ret = ;
while(x>) ret = ret+sum[x] , x-=lowbit(x);
return ret;
} int main()
{
//freopen("in.txt" , "r" , stdin);
int T ;
scanf("%d" , &T);
while(T--){
scanf("%d" , &n);
memset(sum , , sizeof(sum));
for(int i= ; i<=n ; i++)
scanf("%d" , &a[i]); scanf("%d" , &m);
for(int i= ; i<m ; i++){
int l , r;
scanf("%d%d" , &l , &r);
qu[i] = (Query){l , r , i};
}
sort(qu , qu+m);
int cur = ;
mp.clear();
for(int i= ; i<=n ; i++){
if(mp.find(a[i]) == mp.end()){
add(i , a[i]);
mp.insert(make_pair(a[i] , i));
}else{
add(i , a[i]);
add(mp[a[i]] , -a[i]);
mp[a[i]] = i;
}
while(qu[cur].r == i){
rec[qu[cur].id] = query(qu[cur].r)-query(qu[cur].l-);
cur++;
}
}
for(int i= ; i<m ; i++) printf("%I64d\n" , rec[i]);
}
return ;
}
HDU 3333 树状数组离线查询的更多相关文章
- hdu 3333 树状数组+离线处理
http://acm.hdu.edu.cn/showproblem.php?pid=3333 不错的题,想了非常久不知道怎么处理,并且答案没看懂,然后找个样例模拟下别人的代码立即懂了---以后看不懂的 ...
- HDU 4630 No Pain No Game 树状数组+离线查询
思路参考 这里. #include <cstdio> #include <cstring> #include <cstdlib> #include <algo ...
- hdu 3333(树状数组 + 离线操作)
Turing Tree Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- hdu 1556 树状数组+点查询
树状数组 N个气球排成一排,从左到右依次编号为1,2,3....N.每次给定2个整数a b(a <= b),lele便为骑上他的“小飞鸽"牌电动车从气球a开始到气球b依次给每个气球涂一 ...
- bzoj 2743 树状数组离线查询
我们按照询问的右端点排序,然后对于每一个位置,记录同颜色 上一个出现的位置,每次将上上位置出现的+1,上次出现的-1,然后 用树状数组维护就好了 /************************** ...
- 【树状数组+离线查询】HDU 3333 Turing Tree
https://www.bnuoj.com/v3/contest_show.php?cid=9149#problem/H [题意] 给定一个数组,查询任意区间内不同数字之和. (n<=30000 ...
- Turing Tree HDU - 3333 (树状数组,离线求区间元素种类数)
After inventing Turing Tree, 3xian always felt boring when solving problems about intervals, because ...
- hdu 3333 树状数组
思路:定义一个map容器用来记录数ai上次出现的位置.将查询区间按右边界升序进行排序,当插入第i个数ai时,pre[ai]+1---->i的区间就会多一个不同的数,其值就是ai,那么可以用upd ...
- SPOJ DQUERY树状数组离线or主席树
D-query Time Limit: 227MS Memory Limit: 1572864KB 64bit IO Format: %lld & %llu Submit Status ...
随机推荐
- ajax上传文件,并检查文件类型、检查文件大小
1.使用ajaxfileupload.js的插件,但是对插件做了一处修改,才能够正常使用 修改的部分如下: uploadHttpData: function (r, type) { var data ...
- 工作流学习——重要概念扫盲篇一步曲 (zhuan)
http://blog.csdn.net/zwk626542417/article/details/46592471 ***************************************** ...
- css 颜色渐变
.top_nav { width: 100%; height: 29px; /* 如果浏览器不支持渐变,使用图像作为背景 */ background: u ...
- 深入理解PHP原理之变量作用域
26 Aug 08 深入理解PHP原理之变量作用域(Scope in PHP) 作者: Laruence( ) 本文地址: http://www.laruence.com/2008/08/26 ...
- VC++编译zlib
目录 第1章简介 1 第2章版本1.2.3 2 2.1 编译汇编代码 2 2.1.1 32位汇编 2 2.1.2 64位汇编 5 2.2 Visual C++ 6.0 ...
- 实战微信JS SDK开发:贺卡制作与播放(1)
前段时间忙于CanTK 2.0的开发,所以博客一直没有更新.CanTK 2.0主要增强了游戏和富媒体的开发,现在编码和测试基本完成了,等文档完成了再正式发布,里面有不少激动人心的功能,等发布时再一一细 ...
- 能源项目xml文件 -- app-context.xml
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- canvas实现绘画
html代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...
- [JavaScript] 函数同名问题
存在同名函数时,最后的函数会覆盖掉以前的同名函数. var x = 1, y = z = 0; function add(n) { return n = n + 1; } y = add(x); fu ...
- 自定义jQuery插件Step by Step
1.1.1 摘要 随着前端和后端技术的分离,各大互联网公司对于 Mobile First理念都是趋之若鹜的,为了解决网页在不同移动设备上的显示效果,其中一个解决方案就是Responsive Desig ...