当前位置:网站首页>(2022牛客多校五)B-Watches(二分)
(2022牛客多校五)B-Watches(二分)
2022-08-02 06:45: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;
}
边栏推荐
- 在VMware上安装Metasploitable2
- Two good php debug tutorials
- 每周推荐短视频:为什么产品开发需要数字化?如何做到数字化?
- 解决:- SPY: No data found for this date range, symbol may be delisted报错
- 张驰课堂:六西格玛测量系统的误差分析与判定
- [21天学习挑战赛——内核笔记](一)——设备树的概述(硬件、目标、效果、文件类型)
- [Dataset][VOC] Eyewear dataset 6000 in VOC format
- 实例031:字母识词
- MQ带来的一些问题、及解决方案
- File upload vulnerability (2)
猜你喜欢

MQ带来的一些问题、及解决方案

See the picture to understand | How to choose sales indicators to measure the health of business growth

数据库概论之MySQL表的增删改查2

论文《Deep Multifaceted Transformers for Multi-objective Ranking in Large-Scale E-commerce Recommender》

【请教】SQL语句按列1去重来计算列2之和
——设备树的概述(硬件、目标、效果、文件类型)](/img/c6/6c2321bfcd184886e1cb59664bec11.png)
[21天学习挑战赛——内核笔记](一)——设备树的概述(硬件、目标、效果、文件类型)

实例028:递归求等差数列

【图像去噪】基于matlab双立方插值和稀疏表示图像去噪【含Matlab源码 2009期】

你认同这个观点吗?大多数企业的数字化都只是为了缓解焦虑

实例031:字母识词
随机推荐
牛客编程题中——需要处理输入较大数的题目
【CNN回归预测】基于matlab卷积神经网络CNN数据回归预测【含Matlab源码 2003期】
逆变器绝缘检测检测功能及软件实现
C# FileInfo class
SimpleChannelInboundHandler使用总结
SQL执行顺序
mysql 注入
HCIP day 3 experiment
【ROS基础】map、odom、base_link、laser 的理解 及其 tf 树的理解
Analysis of GCC compiler technology
实例032:反向输出II
飞桨paddle技术点整理
【暑期每日一题】洛谷 P1192 台阶问题
php删除一维数组中一个值
海缆探测仪TSS350(二)
PWA 踩坑 - 第一次加载页面后无法获取CacheStorage某些资源
Expert Insights | 3 ways to seize innovation opportunities in a downturn
【暑期每日一题】洛谷 P1255 数楼梯
线程的创建方式
【暑期每日一题】洛谷 P3156 【深基15.例1】询问学号