http://acm.split.hdu.edu.cn/showproblem.php?pid=5919

题意:
给出一串序列,每次给出区间,求出该区间内不同数的个数k和第一个数出现的位置(将这些位置组成一个新的序列),输出这里面的第ceil(k/2)个数。

思路:

因为每个区间只需要统计第一个数出现的位置,那么从右往左来建树,如果该数没有出现,那么就将该位置+1,否则要将上一次出现的位置-1后再在该位置+1。

统计不同数的个数很简单,就是线段树查询。

查询出第k小的数也很简单,因为我们是从后往前建树的,那么t[l]这棵树里面的元素就是从l开始的数组,直接线段树查询第k个数即可。

 #include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<vector>
#include<stack>
#include<queue>
#include<cmath>
#include<map>
#include<set>
using namespace std;
typedef long long ll;
typedef pair<int,int> pll;
const int INF = 0x3f3f3f3f;
const int maxn = *1e5+; int tot,n,m;
int a[maxn],pre[maxn],rot[maxn]; struct node
{
int l,r,num;
}t[maxn*]; int build(int l, int r)
{
int root=++tot;
t[root].num=;
if(l==r) return root;
int mid=(l+r)>>;
t[root].l=build(l,mid);
t[root].r=build(mid+,r);
return root;
} int update(int root, int pos, int d)
{
int now = ++tot;
int tmp = now;
t[tot].num = t[root].num + d;
int l = , r = n;
while(l<r)
{
int mid = (l+r)>>;
if(pos<=mid)
{
t[now].l = ++tot;
t[now].r = t[root].r;
root = t[root].l;
now = tot;
r = mid;
}
else
{
t[now].l = t[root].l;
t[now].r = ++tot;
root = t[root].r;
now = tot;
l = mid + ;
}
t[now].num = t[root].num + d;
}
return tmp;
} int query(int ql ,int qr, int l, int r, int root)
{
if(ql<=l && qr>=r) return t[root].num;
int mid = (l+r)>>;
int ans = ;
if(ql<=mid) ans+=query(ql,qr,l,mid,t[root].l);
if(qr>mid) ans+=query(ql,qr,mid+,r,t[root].r);
return ans;
} int calc(int l,int r,int k,int root)
{
if(l==r) return l;
int mid = (l+r)>>;
if(t[t[root].l].num>=k) return calc(l,mid,k,t[root].l);
else return calc(mid+,r,k-t[t[root].l].num,t[root].r);
} int main()
{
//freopen("in.txt","r",stdin);
int T;
int kase = ;
scanf("%d",&T);
while(T--)
{
tot=;
int bef=;
memset(pre,-,sizeof(pre));
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++) scanf("%d",&a[i]);
rot[n+] = build(,n);
for(int i=n;i>;i--)
{
if(pre[a[i]] == -) rot[i] = update(rot[i+],i,);
else
{
int tmp = update(rot[i+],pre[a[i]],-);
rot[i] = update(tmp,i,);
}
pre[a[i]] = i ;
}
printf("Case #%d:",++kase);
while(m--)
{
int l,r;
scanf("%d%d",&l,&r);
int ll = (l + bef)%n + ;
int rr = (r + bef)%n + ;
l = min(ll, rr);
r = max(ll, rr);
int k = query(l,r,,n,rot[l]);
k = ceil(k/2.0);
int ans = calc(,n,k,rot[l]);
bef = ans;
printf(" %d",ans);
}
puts("");
}
return ;
}

HDU 5919 Sequence II(主席树+区间不同数个数+区间第k小)的更多相关文章

  1. HDU 5919 Sequence II 主席树

    Sequence II Problem Description   Mr. Frog has an integer sequence of length n, which can be denoted ...

  2. HDU 5919 - Sequence II (2016CCPC长春) 主席树 (区间第K小+区间不同值个数)

    HDU 5919 题意: 动态处理一个序列的区间问题,对于一个给定序列,每次输入区间的左端点和右端点,输出这个区间中:每个数字第一次出现的位子留下, 输出这些位子中最中间的那个,就是(len+1)/2 ...

  3. hdu 5919--Sequence II(主席树--求区间不同数个数+区间第k大)

    题目链接 Problem Description Mr. Frog has an integer sequence of length n, which can be denoted as a1,a2 ...

  4. HDU 5919 Sequence II(主席树+逆序思想)

    Sequence II Time Limit: 9000/4500 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) To ...

  5. HDU 5919 -- Sequence II (主席树)

    题意: 给一串数字,每个数字的位置是这个数第一次出现的位置. 每个询问对于序列的一个子区间,设一共有k个不同的数,求第ceil(k/2)个数的位置. 因为强制在线,所以离线乱搞pass掉. 主席树可解 ...

  6. HDU 5919 Sequence II(主席树)题解

    题意:有A1 ~ An组成的数组,给你l r,L = min((l + ans[i - 1]) % n + 1, (r + ans[i - 1]) % n + 1),R = max((l + ans[ ...

  7. hdu 5919 Sequence II (可持久化线段树)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=5919 大致题意: 给你一个长度为n的序列,q个询问,每次询问是给你两个数x,y,经过与上一次的答案进行运算 ...

  8. HDU5919 Sequence II(主席树)

    Mr. Frog has an integer sequence of length n, which can be denoted as a1,a2,⋯,ana1,a2,⋯,anThere are ...

  9. HDU - 5919 Sequence II

    题意: 给定长度为n的序列和q次询问.每次询问给出一个区间(L,R),求出区间内每个数第一次出现位置的中位数,强制在线. 题解: 用主席树从右向左的插入点.对于当前点i,如果a[i]出现过,则把原位置 ...

随机推荐

  1. Thread(26)

    1.进程:进程指正在运行的程序.确切的来说,当一个程序进入内存运行,即变成一个进程,进程是处于运行过程中的程序,并且具有一定独立功能. 2.线程:线程是进程中的一个执行单元,负责当前进程中程序的执行, ...

  2. Javascript创建类的七种方法

    /* 第一种定义类的方法 */var cls = new Object();cls.name = "wyf";cls.showName = function(){console.l ...

  3. linux python虚拟环境 相关的

    为什么要用虚拟环境 在使用python开发过程中,各种业务需求多了,导致工程任务多了,难免会碰到不同的工程依赖不同版本库的问题,;或者是在开发的时候不想让物理环境里充斥各种各样的库,引发依赖环境灾难, ...

  4. 前端框架VUE----webpack打包工具的使用

    在这里我仅仅的是对webpack做个讲解,webpack这个工具非常强大,解决了我们前端很繁琐的一些工具流程繁琐的事情.如果感兴趣的同学,还是看官网吧. 中文链接地址:https://www.webp ...

  5. css实现16:9的图片比例

    摘自:https://www.cnblogs.com/caizhenbo/p/css.html 需求: 最近产品要求不管原图的大小是多少,宽度一定,高度要自自适应为16:9. 分析: 对于正常的固定好 ...

  6. 瀑布流之ajax

    wf_js.html(展示页) <!DOCTYPE html> <html> <head> <meta charset="utf-8" / ...

  7. mxnet下如何查看中间结果

    https://blog.csdn.net/disen10/article/details/79376631 固定权重:https://www.cnblogs.com/chenyliang/p/678 ...

  8. jbpm 6 vs activities 5评估(持续更新、亲测实际项目评估)

    最近我们有个使用了jbpm 6.2(6.2是一个较大的里程碑)的批处理模块,因为大BOSS一直觉得太重了,希望有更加轻量级的解决方案,因为我们基本上没有真正意义上流程的概念,只有静态的流程图,因为一直 ...

  9. maven的使用记录

    maven的使用记录 使用的版本为3.6.0. maven配置部署项目 在cmd命令行中切换到Maven项目的根目录,比如:D:/xxxwork/java/maven-test,然后执行命令:$ mv ...

  10. VSCode 预览 .md 文件

    VSCode安装md插件 选择Extensions, 输入Markdown Theme Kit,下面会出现相应插件,点击install(截图中因为我已经安装,所以是设置) 或者安装插件Markdown ...