当前位置:网站首页>(2022牛客多校五)B-Watches(二分)
(2022牛客多校五)B-Watches(二分)
2022-08-08 23:06:00 【AC__dream】
题目:
样例输入:
4 5
3 4 5 6
样例输出:
1
题意:给定n件商品的价格,如果你选购第k件商品,那么购买第i件物品的花费就是ai+k*i,问m元最多能买多少件(第i件是原序列中的第i个)
分析:我们容易发现的一点是答案具有单调性,我能买k件物品,那么我就一定能买k-1件商品,这是显然的,所以我们就可以对商品进行排序,对于每次二分的k我们都需要按照ai+k*i按照从小到大进行排序,然后从前往后贪心地选取即可,看用m元最多能买多少件商品,如果大于k返回true,否则返回false。
下面是代码:
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<map>
#include<queue>
#include<vector>
#include<cmath>
using namespace std;
const int N=1e5+10;
struct node{
int id,v;
}p[N];
int mid,n,m;
bool cmp(node a,node b)
{
return a.v+a.id*mid<b.v+b.id*mid;
}
bool check(int k)
{
long long ans=0;
sort(p+1,p+n+1,cmp);
for(int i=1;i<=k;i++)
ans+=p[i].v+1ll*p[i].id*k;
return ans<=m;
}
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
scanf("%d",&p[i].v),p[i].id=i;
int l=0,r=n;
while(l<r)
{
mid=l+r+1>>1;
if(check(mid)) l=mid;
else r=mid-1;
}
printf("%d",l);
return 0;
}
边栏推荐
猜你喜欢
Xcode creates a Dylib plugin deb project
windows10安装vagrant+VirtualBox搭建PHP开发环境
如何实现call、apply、bind
【YOLOv5】6.0环境搭建(不定时更新)
2022牛客多校六 B-Eezie and Pie (dfs)
MySQL8.0 及 SQL 注入
MES docks with Simba to realize IMEI number writing and coupling test of Spreadtrum platform
ArcPy要素批量转dwg
动态主机配置协议DHCP(DHCPv4)
用工具实现 Mock API 的整个流程
随机推荐
Analysis of WLAN - Wireless Local Area Network
设计分享|基于单片机的P0口驱动LED闪烁
二叉树 层次遍历 及例题
微信小程序“反编译”实战”解包 后面有彩蛋
【PP-YOLOv2】测试自定义的数据集
CTF攻防世界
iptables firewall content full solution
【Tensorflow2】tensorflow1.x-tensorflow2.x一些接口的转变
wps表格分两页断开怎么办?wps表格分两页断开的解决方法
flutter 基本类写法
使用Mongoose populate实现多表关联存储与查询,内附完整代码
stm32 利用 串口接收空闲中断 + dma 实现不定长度dma 接收
GIL和池的概念
按键精灵 for ts API 使用
让IPv6强大的关键——NDP邻居发现协议
【Pytorch】学习笔记(一)
meta learning
深拷贝与浅拷贝
word文档标题怎么自动编号?
每日一R「01」跟着大佬学 Rust