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 ...
随机推荐
- 使用使用dockerfile构建webapi镜像然后使用link和bridge两种方式进行桥接
首先新增一个webapi的项目 项目核心代码 UserContext using Microsoft.EntityFrameworkCore; using System; using System.C ...
- Powershell 脚本输出前十条消耗内存的进程到excel
# create new excel instance $objExcel = New-Object -comobject Excel.Application $objExcel.Visible = ...
- maven指定本地jar包
来自 https://blog.csdn.net/zhengxiangwen/article/details/50734565 一.怎么添加jar到本地仓库呢?步骤:1.cmd命令进入该jar包所在路 ...
- 腾讯云从零搭建PHP运行环境
一.首先我们得注册腾讯云,租用一台服务器,我选择的是CentOS 7.2 64位,这时候会给你这台主机的公网IP和内网IP,以及这台主机的用户名及密码. 二.我们可以使用腾讯云网页上自带的登录按钮进行 ...
- jquery导航栏高亮(二级菜单点击一级保持高亮)
<script type="text/javascript"> var urlstr = location.href; var urlstatus=false; $(& ...
- org.apache.httpcomponents:httpclient 工具类
基于httpclient 版本4.4.1 因为http连接需要三次握手,在需要频繁调用时浪费资源和时间 故采用连接池的方式连接 根据实际需要更改 连接池最大连接数.路由最大连接数 另一个需要注意的是 ...
- python常量 (最全常量解析)
常量 一.常量 变量是变化的量,常量则是不变的量.python中没有使用语法强制定义常量,也就是说,python中定义常量本质上就是变量.如果非要定义常量,变量名必须全大写. AGE_OF_NICK ...
- Excel如何通过关键字模糊匹配查找全称
打开excel,以其素材为例,通过关键字模糊匹配查找全称. 在公司名下输入公式:=LOOKUP(1,0/FIND(D2,A2:A5),A2:A5),按回车键确定即可. FIND(D2,A2:A ...
- STL 之 queue
默认容器为双端队列deque 常用的函数有: empty Test whether container is empty (public member function ) size Return s ...
- http协议中常见的状态码以及请求方式,http协议的组成
请求状态码: 2xxx:表示请求成功,例如200. 3xxx:表示请求被重定向,表示完成请求,需要进一步操作,例如 302. 4xxx:表示请求错误,例如:404,资源没有找到. 5xxx:表示服务器 ...