HDU 6287 Just h-index
Time limit 3000 ms
Memory limit 132768 kB
OS Windows
Source CCPC2018-湖南全国邀请赛-重现赛(感谢湘潭大学)
中文题意
一个序列,每次询问一个区间,要求一个最大的h,使区间内有h个数字大于等于h。
解题思路
我用的在线做法,主席树套二分,对于每个区间,二分k的值,看看这个第k大的数是否大于等于k(是否有k个大于等于k的数)
- 如果大于等于(前k大的数都大于等于k),那么就更新答案,并且将增大k的值(\(ll=mid+1\))
- 如果小于(前k大的数存在小于k的),那么就减小k的值(\(rr=mid-1\))
由于主席树板子是求第k小的,所以二分那里做了些变化,转换成第k大。
网上还有离线做法:莫队套权值树状数组套二分,我先留坑。
源代码
#include<stdio.h>
#include<algorithm>
int n,m;
int a[100010];
struct Node{
int lson,rson;
int sum;
}t[4000010];
int root[100010],cnt;
void build(int &x,int l,int r)
{
x=cnt++;
t[x]={0,0,0};
if(l==r)
{
t[x].sum=1;
return;
}
int mid=l+r>>1;
build(t[x].lson,l,mid);
build(t[x].rson,mid+1,r);
t[x].sum=t[t[x].lson].sum+t[t[x].rson].sum;
}
void update(int &x,int pre,int l,int r,int pos)
{
x=cnt++;
t[x] = t[pre];
t[x].sum++;
if(l==r) return;
int mid=l+r>>1;
if(pos<=mid)
update(t[x].lson,t[pre].lson,l,mid,pos);
else
update(t[x].rson,t[pre].rson,mid+1,r,pos);
}
int que(int x,int pre,int l,int r,int k)
{
if(l==r) return l;
int delta=t[t[x].lson].sum-t[t[pre].lson].sum,mid=l+r>>1;
if(k<=delta)
return que(t[x].lson,t[pre].lson,l,mid,k);
else
return que(t[x].rson,t[pre].rson,mid+1,r,k-delta);
}
int main()
{
freopen("test.in","r",stdin);
while(~scanf("%d%d",&n,&m))
{
cnt=0;
build(root[0],1,n);
for(int i=1;i<=n;i++)
{
scanf("%d",a+i);
update(root[i],root[i-1],1,n,a[i]);
}
int l,r;
while(m--)
{
scanf("%d%d",&l,&r);
int ll=1,rr=(r-l+1),ans=0;
while(ll<=rr)
{
int mid=ll+rr>>1,kk=r-l+1-mid+1;//第mid大<=>第kk小
int temp=que(root[r],root[l-1],1,n,kk);//第mid大的数是temp;
if(temp>=mid) ans=std::max(ans,mid),ll=mid+1;
else rr=mid-1;
}
printf("%d\n",ans);
}
}
return 0;
}
HDU 6287 Just h-index的更多相关文章
- hdu 6287 口算训练
题意: 小Q非常喜欢数学,但是他的口算能力非常弱.因此他找到了小T,给了小T一个长度为nn的正整数序列a1,a2,...,ana1,a2,...,an,要求小T抛出mm个问题以训练他的口算能力. 每个 ...
- HDU - 6433: H. Pow (简答题,输出大数)
There are n numbers 3^0, 3^1, . . . , 3^n-1. Each time you can choose a subset of them (may be empty ...
- HDU 6326.Problem H. Monster Hunter-贪心(优先队列)+流水线排序+路径压缩、节点合并(并查集) (2018 Multi-University Training Contest 3 1008)
6326.Problem H. Monster Hunter 题意就是打怪兽,给定一棵 n 个点的树,除 1 外每个点有一只怪兽,打败它需要先消耗 ai点 HP,再恢复 bi点 HP.求从 1 号点出 ...
- HDU-6278-Jsut$h$-index(主席树)
链接: https://vjudge.net/problem/HDU-6278 题意: The h-index of an author is the largest h where he has a ...
- HDU 6326 Problem H Monster Hunter
\(\mathtt{Problem H}\) \(\mathtt{Monster}\) \(\mathtt{Hunter}\) \(\mathcal{Description}\) 题目 给定一棵 \( ...
- HDU - 6287 口算训练 二分+质因数分解
小Q非常喜欢数学,但是他的口算能力非常弱.因此他找到了小T,给了小T一个长度为nn的正整数序列a1,a2,...,ana1,a2,...,an,要求小T抛出mm个问题以训练他的口算能力.每个问题给出三 ...
- hdu 6287
选出来比较合适的博客 https://blog.csdn.net/Tony5t4rk/article/details/80490711 https://blog.csdn.net/Game_Acm/a ...
- HDU 1560 DNA sequence(IDA*)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1560 题目大意:给出n个字符串,让你找一个字符串使得这n个字符串都是它的子串,求最小长度. 解题思路: ...
- hdu 1257 最少拦截系统【贪心 || DP——LIS】
链接: http://acm.hdu.edu.cn/showproblem.php?pid=1257 http://acm.hust.edu.cn/vjudge/contest/view.action ...
随机推荐
- 关于Goroutine与Channel
关于Goroutine的原理 原理上的内容比较多,比如goroutine启动的时候要执行哪些相关的操作,一点一点的补充一下. channel的基本原理 channel是go语言中的特殊的机制,既可以同 ...
- editText内容从hint右输入
如何让editText内容从hint右输入呢: <EditText android:id="@+id/et_password" android:textColor=" ...
- Marked Ancestor
一道并查集的题目硬是被我当成线段树写了,感觉这样写虽然不是最好的,不过能a就行 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=103906 ...
- 使用ntpdate 同步 linux的时间
1. linux 查看时间和时区的命令 timedatectl 效果为: Local time: Sun -- :: CST Universal time: Sun -- :: UTC RTC tim ...
- (4.25)Sqlserver中 登录用户只能看到自己拥有权限的库
Sqlserver中 登录用户只能看到自己拥有权限的库 转自:https://www.cnblogs.com/huangtailang/p/4209180.html 相关参考:https://www. ...
- CSS中BFC规则
何为BFC BFC(Block formatting context)直译为"块级格式化上下文".它是一个独立的渲染区域,只有Block-level box参与, 它规定了内部的B ...
- Luogu P5339 [TJOI2019]唱、跳、rap和篮球
题目 设\(f_i\)表示从\((a-4i,b-4i,c-4i,d-4i)\)中选\(n-4i\)个排队的方案数. 那么我们可以容斥,答案为\(\sum\limits_{i=0}^{lim}(-1)^ ...
- 解决keil5中文注释乱码方法
菜单上面的edit-->Configuration-->Editor-->Encoding 选择Chinese GB2312 点击OK即可解决 参考 解决keil和source in ...
- 卸载yum-mysql
注意事项:1. 卸载yum MYSQLsystemctl status mysqlsystemctl stop mysqlsystemctl disable mysqld rpm -qa | grep ...
- Python 多列数据存储
zip()函数 zip函数可以把多个列表相加成一个tuple(元组) a = [1,2,3,4] b = [11,22,33,44] c = [111,222,333,444] A = list(zi ...