Super Mario HDU 4417 主席树区间查询

题意

给你n个数(编号从0开始),然后查询区间内小于k的数的个数。

解题思路

这个可以使用主席树来处理,因为这个很类似查询区间内的第k小的问题。当然我们需要进行离散化,不只是那n个数,k也需要进行离散化。

详情看代码吧,有注释。

代码实现

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
const int maxn=1e5+7;
struct node{
int l, r, sum;
}t[maxn*40];
int root[maxn], cnt;
int a[maxn];
vector<int> v;
int n, m, tot;
int getid(int x) //离散化获取编号,从1开始
{
return lower_bound(v.begin() , v.end() , x) - v.begin() +1;
}
void update(int l, int r, int pre, int &now, int pos)
{
t[++cnt]=t[pre];
t[cnt].sum++;
now=cnt;
if(l==r) return ;
int mid=(l+r)>>1;
if(pos<=mid)
update(l, mid, t[pre].l, t[now].l, pos);
else
update(mid+1, r, t[pre].r, t[now].r, pos);
}
int query(int l, int r, int x, int y, int k1)
{
if(r<=k1) return t[y].sum-t[x].sum; //如果第k1小大于r边界,那么这个区间内的出现的所有数都小于k1
if(l==r) //如果到达叶子节点,那么需要判断这个点在这个区间内是否出现过。
return t[y].sum-t[x].sum > 0 ? 1 : 0 ;
int mid=(l+r)>>1;
int sum=t[t[y].l].sum - t[t[x].l].sum; //计算左子树区间内的出现的数字的个数。
if(k1<=mid)
return query(l, mid, t[x].l, t[y].l, k1); //如果在左子树的话,需要进行递归。
else
return sum+query(mid+1, r, t[x].r, t[y].r, k1);//如果在右子树的话就需要加上左边区间内出现的数的个数。
}
void init() //初始化
{
cnt=0;
v.clear();
}
int main()
{
int t;
scanf("%d", &t);
for(int ca=1; ca<=t; ca++)
{
init();
scanf("%d%d", &n, &m);
for(int i=1; i<=n; i++)
{
scanf("%d", &a[i]);
v.push_back(a[i]);
}
//离散化
sort(v.begin(), v.end() );
v.erase( unique(v.begin() , v.end() ) , v.end() );
tot=v.size(); //tot记录去重之后数的个数。
for(int i=1; i<=n; i++)
{
update(1, tot, root[i-1], root[i], getid(a[i])); //建立主席树
}
int x, y, k;
printf("Case %d:\n", ca);
for(int i=1; i<=m; i++)
{
scanf("%d%d%d", &x, &y, &k);
x++; y++; //因为题目是从0开始编号的,所以对于询问我们要加1
if(k<=0 && v[0]>0 || k<v[0]) //结果为0的情况
printf("0\n");
else if(k>=v[tot-1])//结果为所查区间的情况
{
printf("%d\n", y-x+1);
}
else
{
int tmp=getid(k);//因为我用的是lower_bound(),返回第一个大于或者等于的位置,
if(v[tmp-1] > k)//如果不等于的话,范围需要缩小一个
printf("%d\n", query(1, tot, root[x-1], root[y], tmp-1) );
else printf("%d\n", query(1, tot, root[x-1], root[y], tmp) );
}
}
}
return 0;
}

Super Mario HDU 4417 主席树区间查询的更多相关文章

  1. Super Mario HDU - 4417 (主席树询问区间比k小的个数)

    Mario is world-famous plumber. His “burly” figure and amazing jumping ability reminded in our memory ...

  2. J - Super Mario HDU - 4417 线段树 离线处理 区间排序

    J - Super Mario HDU - 4417 这个题目我开始直接暴力,然后就超时了,不知道该怎么做,直接看了题解,这个习惯其实不太好. 不过网上的思路真的很厉害,看完之后有点伤心,感觉自己应该 ...

  3. Super Mario HDU - 4417 (主席树)

    Mario is world-famous plumber. His “burly” figure and amazing jumping ability reminded in our memory ...

  4. AC日记——Super Mario hdu 4417

    Super Mario Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  5. HDU 4417 主席树写法

    Super Mario Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  6. hdu 5919 主席树(区间不同数的个数 + 区间第k大)

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

  7. hdu4417(Super Mario)—— 二分+划分树

    Super Mario Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  8. HDU 2852 主席树

    KiKi's K-Number Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  9. HDU 2655 主席树

    Kth number Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

随机推荐

  1. ZROI 19.07.28 序列数据结构/jk

    写在前面 dls:"我不会数据结构,但是APIO的数据结构场我写了,还是蛮简单的." T1 CF643G Sol: 有一个\(O(n\log^2n)\)的做法:假设将区间排好序,取 ...

  2. python如何调用c编译好可执行程序

    python如何调用c编译好可执行程序       以下总结出几种在Python 中调用 C/C++ 代码的方法 ------------------------------------------- ...

  3. layui js动态添加的面板不能折叠

    layui 动态添加dom后一般调用 layer.form.render()更新dom就可以了,但是我动态添加一个面板后form.render()就没有效果,要用layui.element.rende ...

  4. 【leetcode】1177. Can Make Palindrome from Substring

    题目如下: Given a string s, we make queries on substrings of s. For each query queries[i] = [left, right ...

  5. 微信小程序-坑1-await-async

    VM45:1 thirdScriptError sdk uncaught third Error regeneratorRuntime is not defined ReferenceError: r ...

  6. winform最小化及添加右键

    private void PrintService_SizeChanged(object sender, EventArgs e) { if (this.WindowState == FormWind ...

  7. python3 -m pip install django, -m参数

    python -m xxx.py 作用是:把xxx.py文件当做模块启动但是我一直不明白当做模块启动到底有什么用.python xxx.py和python -m xxx.py有什么区别! 自问自答: ...

  8. Retina 屏幕与二倍图

    分辨率 屏幕分辨率:指屏幕可显示的像素的个数 图像分辨率:位图图像包含的像素的个数 对于 Retina 屏它的分辨率是传统屏的两倍,而屏幕大小没有变化,所以它需要的图片的分辨率应该是传统屏幕的两倍(甚 ...

  9. ssh连接MAC服务器显示No route to host解决方法

    首先MAC操作系统是10 其它电脑通过ssh访问一台mac服务器时,有时候可以登录进去,有显示显示no route to host 并且通过浏览器访问布署在mac上的jenkins,反应奇慢,后来做了 ...

  10. SVN 客户端不显示图标解决方案

    下图为没有设置之前,文件夹不显示svn图标 SVN客户端不显示图标解决方案:右键svn->设置->图标覆盖->状态缓存选择"Windows外壳"->确定,刷 ...