[CSP-S模拟测试]:分组配对(倍增+二分)
题目传送门(内部题108)
输入格式
输入文件第一行为两个正整数$n,M$。
接下来两行,第一行为$n$个正整数$a_1\sim a_n$,其中$a_i$表示编号为$i$的男生的实力值;第二行为$n$个正整数$b_1\sim b_n$,其中$b_i$表示编号为$i$的女生的实力值。
输出格式
输出一个整数,为最少的小组数量。输入数据保证至少存在一种满足分组规则的分组方式。
样例
样例输入:
3 50
6 7 2
6 3 5
样例输出:
2
数据范围与提示
对于$10\%$的数据,满足$n\leqslant 10$。
对于$30\%$的数据,满足$n\leqslant 1,000$。
对于$50\%$的数据,满足$n\leqslant 10,000$。
对于$70\%$的数据,满足$n\leqslant 100,000$。
对于$100\%$的数据,满足$n\leqslant 500,000,1\leqslant a_i,b_i\leqslant 100,000,1\leqslant M\leqslant 10^{15}$。
题解
先来考虑一种接近正解的做法,对于当前的左端点,二分右端点的位置,然后$judge$。
但是算一算时间复杂度发现并不对,最极限的数据就是每一组都只有一个人,那么时间复杂度就是$\Theta(n^2\log^2n)$的了。
考虑优化,可以先利用倍增求出范围,即为如果$l+2^p$可以,但是$l+2^{p+1}$不可以,然后再在这段区间内进行二分即可。
因为无论是倍增还是二分,都只将整个序列$judge$了$k$遍,这里$k$只是一个很小的常数,所以复杂度就是对的了。
注意不要被$a_i,b_i$的值域迷惑,千万不要使用桶排,因为对于这种算法,桶排的时间复杂度还是$\Theta(n^2\log^2n)$级别的。
时间复杂度:$\Theta(n\log^n)$。
期望得分:$100$分。
实际得分:$100$分。
代码时刻
#include<bits/stdc++.h>
using namespace std;
int n;
long long M;
int a[500001],b[500001],qa[500001],qb[500001];
int ans;
bool judge(int l,int r)
{
long long res=0;
for(int i=l;i<=r;i++){qa[i]=a[i];qb[i]=b[i];}
sort(qa+l,qa+r+1);sort(qb+l,qb+r+1);
for(int i=l;i<=r;i++){res+=1LL*qa[i]*qb[i];if(res>M)return 0;}
return 1;
}
int main()
{
scanf("%d%lld",&n,&M);
for(int i=1;i<=n;i++)
scanf("%lld",&a[i]);
for(int i=1;i<=n;i++)
scanf("%lld",&b[i]);
int now=1;
while(now<=n)
{
ans++;
int lft=0,rht=0,res=now;
while(1)
{
if(now+(1<<rht)>n)break;
if(!judge(now,now+(1<<rht)))break;
lft=rht;rht++;
}
lft=now+(1<<lft);
rht=min(now+(1<<rht),n);
while(lft<=rht)
{
int mid=(lft+rht)>>1;
if(judge(now,mid)){lft=mid+1;res=mid;}
else rht=mid-1;
}
now=res+1;
}
nxt:;
printf("%d",ans);
return 0;
}
rp++
[CSP-S模拟测试]:分组配对(倍增+二分)的更多相关文章
- 联赛模拟测试22 B. 分组配对 倍增+二分
题目描述 分析 首先,容易发现一个小组内的最优配对方式(能得到最大综合实力的方式) 一定是实力值最大的男生和最大的女生配对,次大的和次大的配对,以此类推. 但是每次新插入一个值时,需要用 \(nlog ...
- [CSP-S模拟测试]:C(倍增+数学)
题目传送门(内部题152) 输入格式 第一行两个整数$N,Q$. 接下来一行$N$个整数,第$i$个为$a_i$. 接下来的$N-1$行,每行两个整数$u,v$.表示$u,v$之间有一条边. 接下来的 ...
- [CSP-S模拟测试]:中间值(二分)
题目背景 $Maxtir$喜欢序列的中间值. 题目传送门(内部题127) 输入格式 第一行输入两个正整数$n,m$,其中$m$是操作和询问次数. 接下来两行每行输入$n$个非负整数,每一行分别表示两个 ...
- 2019.8.3 [HZOI]NOIP模拟测试12 C. 分组
2019.8.3 [HZOI]NOIP模拟测试12 C. 分组 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 刚看这题觉得很难,于是数据点分治 k只有1和2两种,分别 ...
- csp-s模拟测试96
csp-s模拟测试96 $T1$一眼慢速乘,$T2$稍证一手最优性尝试用神奇数据结构优化,无果,弃.$T3$暴力+信仰. 100 03:16:38 95 03:16:56 35 03:17:10 23 ...
- [考试反思]1031csp-s模拟测试96:常态
按照smily的说法这一场的大众分暴力分是不是265啊QwQ那我可真是个大垃圾 总算还是回归了常态. T3文件名写错,把“city.in”写成“city,in” 还好,只丢了20分. T2乱打$O(n ...
- [CSP-S模拟测试96]题解
以后不能再借没改完题的理由不写题解了…… A.求和 求$\sum \sum i+j-1$ 柿子就不化了吧……这年头pj都不考这么弱智的公式化简了…… 坑点1:模数不定,可能没有2的逆元,那么只要先把乘 ...
- [2018冬令营模拟测试赛(二十一)]Problem A: Decalcomania
[2018冬令营模拟测试赛(二十一)]Problem A: Decalcomania 试题描述 输入 见"试题描述" 输出 见"试题描述" 输入示例 见&quo ...
- [考试反思]1003csp-s模拟测试58:沉淀
稳住阵脚. 还可以. 至少想拿到的分都拿到了,最后一题的确因为不会按秩合并和线段树分治而想不出来. 对拍了,暴力都拍了.挺稳的. 但是其实也有波折,险些被卡内存. 如果内存使用不连续或申请的内存全部使 ...
随机推荐
- Git提交代码的小知识
1.需要切换到项目目录下并创建一个Repository用于提交代码到这个仓库里 cd /g/....//cd后面有空格,用于进入某个项目文件夹 git init//用于创建Repository 2.添 ...
- 这38个小技巧告诉你如何快速学习MySQL数据库
1.如何快速掌握MySQL? ⑴培养兴趣兴趣是最好的老师,不论学习什么知识,兴趣都可以极大地提高学习效率.当然学习MySQL 5.6也不例外.⑵夯实基础计算机领域的技术非常强调基础,刚开始学习可能还认 ...
- 埋在 MYSQL 数据库应用中的17个关键问题!
Mysql的使用非常普遍,跟mysql有关的话题也非常多,如性能优化.高可用性.强一致性.安全.备份.集群.横向扩展.纵向扩展.负载均衡.读写分离等.要想掌握其中的精髓,可得花费不少功力,虽然目前流行 ...
- 网速监控-nload
用来监控系统网卡实时网速的. 安装 yum install nload -y # 或 apt install nload -y 使用 # 直接运行默认监控第一个网卡, 使用上下方向键来切换网卡. nl ...
- X-Forwarded-For伪造及防御
使用x-Forward_for插件或者burpsuit可以改包,伪造任意的IP地址,使一些管理员后台绕过对IP地址限制的访问. 防护策略: 1.对于直接使用的 Web 应用,必须使用从TCP连接中得到 ...
- freemarker的replace的使用
1.replace替换: <#assign name="sdfsfdsa\ndfsafs\n"> 例子:${name?replace("\n",&q ...
- python、第七篇:ORM框架SQLAlchemy
一 介绍 SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据API执行SQL并获取 ...
- deep_learning_Function_numpy_argmax()函数
numpy里面的argmax函数 函数原型:def argmax(a, axis=None, out=None)a----输入arrayaxis----为0代表列方向,为1代表行方向out----结果 ...
- Array、Set、Map、Object学习总结
Array和Set对比 都是一个存储多值的容器,两者可以互相转换,但是在使用场景上有区别.如下: Array的indexOf方法比Set的has方法效率低下 Set不含有重复值(可以利用这个特性实现对 ...
- php核心:代际划分/运行环境等
不想在python一棵树上吊死,不是所有Python就一定得会人工智能大数据,so...... 何谓php?早期:personel homepage 是也!后期Hypertext preprocess ...