【BZOJ】4717 改装
来源:互联网 发布:淮阴师范学院网络课程 编辑:程序博客网 时间:2024/04/27 19:24
Description
(题面太长懒得搬)
小Q需要在编号为L到R的船只中选择一艘,并在编号为a和b之间的装备选择一架,组成出击用的船只。于是,小Q总共有(R-L+1)*(b-a+1)种选择,小Q希望知道,所有这些选择中,第k大的能力值是多少。
Input
第一行两个数n,m,空格分隔,表示小Q的船的数量和装备的数量。
第二行n个数,空格分隔,表示小Q的船的能力值(按编号)。
第三行m个数,空格分隔,表示小Q的装备的能力值(按编号)。
第四行一个数q,表示小q的操作数量。
接下来q行,每行描述一个操作,操作要么为一个改修事件,要么为一个询问。
对于改修事件,该行4个数0,type,pos,val,type为0或1,
0表示把pos号船改修成val的能力值
1表示把pos号装备改修成val的能力值。
对于询问操作,该行6个数1,L,R,a,b,k,空格分隔,表示一个询问。
n<=250,m<=100000,q<=100000,其中询问操作不会超过200。
对于100%的数据,1<=L<=R<=n,1<=a<=b<=m,1<=k<=(R-L+1)*(b-a+1)
任何时候船能力值为不超过2000的正整数,装备能力值为不超过1000000的正整数。
Output
对于每个询问操作,输出一行,包含一个数,表示询问的答案。
Solution
200个询问100s的时限……大暴力碾过去。
把对应区间的装备拿出来排序,二分第k大的值,在二分过程中对每艘船二分能带的最强装备。
(坑点:二分k大的值时小心别加爆了int QAQ)
#include<stdio.h>#include<algorithm>using namespace std;int n,m,a[300],b[100003],c[100003],t,p,v,len,up,down,C,q,L,R,l,r,k;inline int judge(const int &a,const int &u){ int l=1,r=len+1; for (int mid=r>>1;l<r;mid=(l+r)>>1) if (a*c[mid]<u) l=mid+1; else r=mid; return len-l+1;}int main(){ scanf("%d%d",&n,&m); for (int i=1;i<=n;i++) scanf("%d",a+i); for (int i=1;i<=m;i++) scanf("%d",b+i); scanf("%d",&q); while (q--) { scanf("%d",&C); if (C==0) { scanf("%d%d%d",&t,&p,&v); if (t==0) a[p]=v;else b[p]=v; } else { scanf("%d%d%d%d%d",&L,&R,&l,&r,&k); for (int i=l;i<=r;i++) c[i-l+1]=b[i]; sort(c+1,c+r-l+2); down=up=0;len=r-l+1; for (int i=L;i<=R;i++) up=max(up,a[i]*c[len]+1); for (int mid=up>>1,tot=0;down<up;mid=((long long)down+up)>>1,tot=0) { for (int i=L;i<=R;i++) tot+=judge(a[i],mid); if (tot<k) up=mid; else down=mid+1; } printf("%d\n",up-1); } }}
0 0
- 【BZOJ】4717 改装
- bzoj 4717: 改装 二分+set
- 改装无惧类上传组件
- 键盘改装完毕
- 广西第一改装EVO
- 今天改装了 Vista
- Tarjan算法的改装
- 改装:大话设计模式
- 小改装一下电暖气
- 改装助力系统资料
- 改装的表格
- 改装氙气灯
- Ubuntu改装Flatabulous主题
- 电动车改装系列
- [BZOJ ]
- BZOJ****-****
- BZOJ
- BZOJ
- 向数组中输入字符串的三种方法
- 排序算法之初级排序
- 编码(2):unicode和utf-8
- android 自定义view属性
- 并发知识与concurrent包
- 【BZOJ】4717 改装
- 播放一个数组中的动画
- DES 加密 解密算法
- 图标的旋转动画
- CNN反向传播公式推导
- win7装linux双系统
- 变量提升/函数提升
- 十四周项目三 折腾二维数组
- 简易计算器