C++课后习题训练记录Day98

1.练习项目:

问题描述

小蓝想要给她的女朋友小桥买一份生日礼物,她来到了一家礼品店。在店里,她看中了 N 件物品,每件物品都有一个价格 Ai。

小蓝手中有 K 元钱和一张 50% 的折扣券,可以在购买任意一件物品时使用。使用折扣券后,购买该物品的价格为原价的一半向上取整。

对于一件价值为 X 的物品,当小蓝使用折扣卷后,他只需要花费 ⌈x/2⌉ 元即可带走该商品。

请帮助小蓝确定,在使用折扣券的情况下,她最多能够购买多少件物品送给小桥作为生日礼物。

输入格式

第一行是两个整数 N 和 K,分别表示物品的数量和小蓝手中的预算。

接下来一行是 N 个整数,表示每个物品的价格 Ai。

数据范围保证:1≤N≤1e5,1≤Ai≤1e9,0≤K≤1e9。

输出格式

输出一个整数,表示在使用折扣券的情况下,小蓝最多可以购买多少件物品作为生日礼物。

2.选择课程

在蓝桥云课中选择课程《16届蓝桥杯省赛无忧班(C&C++ 组)4期》,选择第二章"基础算法"编程30并开始练习。

3.开始练习

(1)源码:

#include<bits/stdc++.h>

using namespace std;

using ll=long long;

priority_queue<ll,vector<ll>,greater<ll>>pq;

int main()

{

ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);

int n,k,x;cin>>n>>k;

for(int i=1;i<=n;i++){

cin>>x;

pq.push(x);

}

ll ans=0;

for(int i=1;i<=n;i++){

if(k==0){

break;

}

ans++;

k-=pq.top();

pq.pop();

if(k-pq.top()<0){

if(k-pq.top()/2+(pq.top()%2?0:1)<0){

break;

}

}

}

cout<<ans<<'\n';

return 0;

}

(2)检验结果

对此代码进行检验,检验后无报错,提交此代码,判题结果为正确100分。

(3)练习心得:注意每段代码末尾的分号是否存在,如不存在则需即使补充;输入法是否切换为英语模式;语法是否错误。

相关推荐
诙_1 天前
由C++速通Lua
开发语言·lua
TechWayfarer1 天前
AI大模型时代:IP数据云如何适配智能体场景需求
开发语言·人工智能·python·网络协议·tcp/ip·langchain
kyle~1 天前
ros_gz_bridge---底层通信的实现
c++·机器人·仿真·ros2
DN金猿1 天前
spring.cloud.nacos.discovery.server-addr和spring.cloud.nacos.server-addr区别
java·开发语言·nacos·springcloud·sca
Jasmine_llq1 天前
《B4261 [GESP202503 三级] 2025》
开发语言·c++·算法·条件判断算法·位运算恒等式推导·简单算术运算
小张成长计划..1 天前
【C++】32:智能指针
c++
海兰1 天前
【实用应用】React+TypeScript+Next.js博客项目
开发语言·javascript·elasticsearch
咩咦1 天前
C++学习笔记19:运算符重载基础与赋值运算符重载
c++·学习笔记·类和对象·运算符重载·赋值运算符·operator
wjs20241 天前
C++ 预处理器
开发语言
lly2024061 天前
《Foundation 提醒框》
开发语言