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 ...
随机推荐
- 求方程x1+x2+x3=15的整数解的数目
求方程x1+x2+x3=15的整数解的数目要求0≤x1≤5,0≤x2≤6,0≤x3≤7.解:令N为全体非负整数解(x1,x2,x3),A1为其中x1≥6的解:y1=x1-6≥0的解:A2为其中x2≥7 ...
- Arm-linux-gcc-4.3.2安装步骤 (转)
http://blog.chinaunix.net/uid-26119896-id-3302233.html 安装交叉编译工具链: 1.首先以root用户登入 2.复制arm-linux-gcc-4. ...
- [转帖]功耗降50%,性能升35%!三星3nm GAA 2021年量产
功耗降50%,性能升35%!三星3nm GAA 2021年量产 http://www.chinaflashmarket.com/Instructor 在三星晶圆代工技术论坛(Samsung Found ...
- shell script简单笔记
变量 shell script是一种脚本语言,变量的定义是通过 myName=HYB 这样的形式定义的. 当存在空格时,可以通过双引号或单引号将其变为字符串.双引号不进行转义,单引号将内容进行转义为一 ...
- springboot工程启动时,报错:No bean named 'shiroFilter' available
在启动Springboot项目时,报错:org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named ' ...
- ajax实现异步请求模态登陆
ajax实现模态登陆 j2ee课程项目实现 Ajax 即"Asynchronous Javascript And XML"(异步 JavaScript 和 XML),是指一种创 ...
- dsu on tree 与长链剖分
dsu on tree 对于树进行轻重链剖分,对于节点 $x$ ,递归所有轻儿子后消除其影响,递归重儿子,不消除其影响. 然后对于所有轻儿子的子树暴力,从而得到 $x$ 的答案. 对于要消除暴力消除即 ...
- TCP/IP四层协议
1.数据链路层 数据链路层实现了网卡接口的网络驱动程序,处理数据在物理媒介(以太网,令牌环)上的传输,常用协议包含ARP(地址解析协议),RARP(逆地址解析协议)两个协议,他们实现了IP地址和物理地 ...
- 更改导航栏的背景和文字Color
更改导航栏的背景和文字Color方法一: [objc] view plaincopy//set NavigationBar 背景颜色&title 颜色 [self.navigationCon ...
- 使用Docker搭建Jumpserver堡垒机
使用Docker搭建Jumpserver堡垒机 1.环境准备 操作系统:CentOS 7.6.1810 软件源:阿里云镜像 #内核版本(Docker 要求 CentOS 系统的内核版本高于 3.10) ...