#include<iostream>
#include<cstdio>
#include<string>
#include<cmath>
#include<cstring>
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll maxn = + ;
ll a[ + ]; struct tree
{
ll l , r;
ll val;
}t[maxn << ]; void push_up(ll rt){
//if(t[rt << 1].val != t[rt << 1|1].val)
t[rt].val = t[rt << ].val + t[rt << |].val;
//else
// t[rt].val += t[rt << 1].val ;
} void build(ll rt,ll l ,ll r){
t[rt].l = l;
t[rt].r = r;
t[rt].val = ;
if(l == r){
//t[rt].val = a[l];
return;
}
ll mid = (l + r) >> ;
build(rt << , l , mid);
build(rt << |,mid+,r);
push_up(rt);
} void updata(ll rt,ll x,ll v){
if(x == t[rt].l && t[rt].r == x){
t[rt].val += v;
return;
}
ll mid = (t[rt].l + t[rt].r) >> ;
if(x <= mid) updata(rt << , x , v);
else updata(rt << |, x , v);
push_up(rt);
} ll query(ll rt,ll l,ll r){
if(l <= t[rt].l && r >= t[rt].r) return t[rt].val;
ll ret = ;
ll mid = (t[rt].l + t[rt].r) >> ;
// if(r <= mid) return query(rt << 1, l, r);
// else if(l > mid) return query(rt << 1|1,l,r);
// else return query(rt << 1,l,mid) + query(rt << 1|1,mid + 1,r);
if (l <= mid) ret += query(rt << , l ,r);
if( r > mid) ret += query(rt << |,l,r);
push_up(rt);
return ret;
} struct node
{
ll x,y,id;
}nod[ + ];
map<ll,ll> mp;
bool cmp(node s1 ,node s2){
//if(s1.y == s2.y)
// return s1.x < s2.x;
return s1.y < s2.y; }
ll ans[ + ];
int main(int argc, char const *argv[])
{
ll tt;
scanf("%lld",&tt);
while(tt--){
ll n;
memset(a,,sizeof a);
memset(t,,sizeof t);
memset(ans,,sizeof ans);
mp.clear();
memset(nod,,sizeof nod);
scanf("%lld",&n);
for(ll i = ;i <= n ; i++){
scanf("%lld",&a[i]);
}
build(,,n);
ll q;
scanf("%lld",&q);
for(ll i = ;i <= q; i++){
ll a,b;
scanf("%lld%d",&a,&b);
//printf("%lld\n",query(1,a,b));
nod[i].x = a,nod[i].y = b,nod[i].id = i;
}
ll i = ;
sort(nod + ,nod + q + ,cmp); for(ll j = ; j <= q;j ++){
for( ;i <= nod[j].y ; i++){
if(mp[a[i]])
//mp[a[i]] = 1; updata(,mp[a[i]],-a[i]);
// mp[a[i]] =
//cout << 1 ;
mp[a[i]] = i;
updata(,i,a[i]);
}
// cout << 3 << endl ;
// cout << nod[j].id << " " << nod[j].x << " " << nod[j].y <<endl;
ans[nod[j].id] = query(,nod[j].x,nod[j].y);
// cout << 1 << endl;
}
// cout << 1 ;
//cout << q << endl;
for(ll i = ;i <= q;i ++){
printf("%lld\n",ans[i] );
}
}
return ;
}

线段树

hdu 3333 离线线段树 + 思维/树状数组 /在线主席树的更多相关文章

  1. SPOJ3267 D-query 离线+树状数组 在线主席树

    分析:这个题,离线的话就是水题,如果强制在线,其实和离线一个思路,然后硬上主席树就行了 离线的代码 #include <iostream> #include <stdio.h> ...

  2. BZOJ2120:数颜色(数状数组套主席树)(带修改的莫对)

    墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会像你发布如下指令: 1. Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色的画笔. 2. R P ...

  3. [bzoj3196][Tyvj1730]二逼平衡树_树套树_位置线段树套非旋转Treap/树状数组套主席树/权值线段树套位置线段树

    二逼平衡树 bzoj-3196 Tyvj-1730 题目大意:请写出一个维护序列的数据结构支持:查询给定权值排名:查询区间k小值:单点修改:查询区间内定值前驱:查询区间内定值后继. 注释:$1\le ...

  4. BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树

    BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排 ...

  5. ZOJ 2112 Dynamic Rankings(树状数组套主席树 可修改区间第k小)题解

    题意:求区间第k小,节点可修改 思路:如果直接用静态第k小去做,显然我更改一个节点后,后面的树都要改,这个复杂度太高.那么我们想到树状数组思路,树状数组是求前缀和,那么我们可以用树状数组套主席树,求出 ...

  6. BZOJ 2141 排队(树状数组套主席树)

    解法很多的题,可以块套树状数组,可以线段树套平衡树.我用的是树状数组套主席树. 题意:给出一段数列,m次操作,每次操作是交换两个位置的数,求每次操作后的逆序对数.(n,m<=2e4). 对于没有 ...

  7. Codeforces Round #404 (Div. 2) E. Anton and Permutation(树状数组套主席树 求出指定数的排名)

    E. Anton and Permutation time limit per test 4 seconds memory limit per test 512 megabytes input sta ...

  8. 【Luogu】P2617Dynamic Ranking(树状数组套主席树)

    题目链接 树状数组套主席树有点难懂qwq 不好理解 树状数组套主席树的直观理解应该是:树状数组的每一个节点是一棵主席树. 普通区间修改我们是创建1个线段树,树状数组套主席树的时候我们就创建log个线段 ...

  9. bzoj1901--树状数组套主席树

    树状数组套主席树模板题... 题目大意: 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1],a[i+2]--a[ ...

随机推荐

  1. 【leetcode】493. Reverse Pairs

    题目如下: 解题思路:本题要求的是数组每个元素和所有排在这个元素后面的元素的值的二倍做比较.我们可以先把数组所有元素的二倍都算出来,存入一个新的数组newlist,并按升序排好.而后遍历nums数组的 ...

  2. linux运维、架构之路-HAProxy反向代理

    一.HAProxy介绍          专业反向代理,支持双机热备支持虚拟主机,配置简单,拥有非常不错的服务器健康检查功能,当其代理的后端节点出现故障, HAProxy会自动将该服务器摘除,故障恢复 ...

  3. Serverless 实战 —— 函数计算 + Typescript 实践

    前言 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute):函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传.函数计算准 ...

  4. 计蒜客 T2237 魔法 分类讨论

    Code: #include<bits/stdc++.h> #define setIO(s) freopen(s".in","r",stdin) # ...

  5. tarjan相关模板

    感性理解: o(* ̄︶ ̄*)o  ^_^ \(^o^)/~ 1. 当根节点有大于两个儿子时,割掉它,剩下的点必然不联通(有两个强连通分量),则他为割点. 那么对于非根节点,在无向图G中,刚且仅当点u存 ...

  6. [luogu]P1053 篝火晚会[数学][群论]

    [luogu]P1053 篝火晚会 题目描述 佳佳刚进高中,在军训的时候,由于佳佳吃苦耐劳,很快得到了教官的赏识,成为了“小教官”.在军训结束的那天晚上,佳佳被命令组织同学们进行篝火晚会.一共有n个同 ...

  7. 3D Computer Grapihcs Using OpenGL - 03 OpenGL Buffer Data

    本节绘制一个三角形,并讲解Buffer Object-缓冲对象 OpenGL的窗口坐标 屏幕中心为坐标原点,横向朝右为x正方向,纵向朝上为y正方向,最大值最小值分别为1,-1. Buffer Obje ...

  8. Minimum Cut

    Minimum Cut Time Limit: 3000/2000 MS (Java/Others)    Memory Limit: 65535/102400 K (Java/Others)Tota ...

  9. SourceTree跳过初始设置

    转载https://www.cnblogs.com/xiofee/p/sourcetree_pass_initialization_setup.html 如何跳过初始设置,只需要在安装路径中添加一个a ...

  10. node.js运行配置(vs code非控制台输出)

    node.js运行配置(vs code非控制台输出) node  配置 简化  vs code 是非常强大的编译器,皆因它有有各种各样好用的插件. 在没有安装code runner插件之前,想要执行n ...