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 ...
随机推荐
- python可视化:matplotlib系列
matplotlib 的官方文档: https://matplotlib.org/users/index.html 1 子图布局管理 布局参数 紧密布局的方法 坐标轴的公用和隐藏 2 直方图bar和b ...
- maven指定本地jar包
来自 https://blog.csdn.net/zhengxiangwen/article/details/50734565 一.怎么添加jar到本地仓库呢?步骤:1.cmd命令进入该jar包所在路 ...
- jQuery中this与$(this)的区别总结
这里就谈谈this与$(this)的区别. 1.jQuery中this与$(this)的区别 $("#textbox").hover( function() { this.titl ...
- CentOS7设置hostname、hosts、静态IP地址、关闭防火墙
针对新安装或者克隆后的虚拟机配置 1. 设置hostname 方法1: centos7 里面修改hostname的方式有所改变,修改/etc/hosts和/etc/sysconfig/network两 ...
- Spark-Core RDD依赖关系
scala> var rdd1 = sc.textFile("./words.txt") rdd1: org.apache.spark.rdd.RDD[String] = . ...
- P1141零一迷宫
这是一道对于除了我之外其他人都十分简单的搜索题,我终于在这个夜里搞会了. 首先其问可以到达多少个点,并不是走一次可以最多经过几个点,这就解释了为什么不需要回溯,并且递归边界则是让其全部走完即可.于是便 ...
- uboot环境变量
一. uboot运行时环境变量分布 1.1. 环境变量有2份,一份在Flash中,另一份在DDR中.uboot开机时一次性从Flash中读取全部环境变量到DDR中作为环境变量的初始化值,然后使用过程中 ...
- [ERROR] Plugin org.apache.maven.plugins:maven-clean-plugin:2.5 or one of its dependencies could not be resolved: Cannot access nexus-aliyun (http://maven.aliyun.com/nexus/content/groups/public) in off
这个错误是将work offline打勾引起的. 这个是离线工作模式,相当于断网,远程的jar会拉不下来.
- Rust学习笔记1
这是一份不错的rust教程,目前包括4个block和4个project.全部完成后可以用rust实现一个简单的key-value存储引擎. 注意:Windows下rust貌似会遇到一些bug,强烈建议 ...
- Hangfire
参考 开源分布式Job系统,调度与业务分离-如何创建一个计划HttpJob任务