当前位置:网站首页>Codeforces - 1526C1&&C2 - Potions
Codeforces - 1526C1&&C2 - Potions
2022-07-06 09:28:00 【你好_Ä】
Codeforces - C1&&C2 - Potions
There are n potions in a line, with potion 1 on the far left and potion n on the far right. Each potion will increase your health by ai when drunk. ai can be negative, meaning that potion will decrease will health.
You start with 0 health and you will walk from left to right, from first potion to the last one. At each potion, you may choose to drink it or ignore it. You must ensure that your health is always non-negative.
What is the largest number of potions you can drink?
Input
The first line contains a single integer n (1≤n≤200000) — the number of potions.
The next line contains n integers a1, a2, … ,an (−109≤ai≤109) which represent the change in health after drinking that potion.
Output
Output a single integer, the maximum number of potions you can drink without your health becoming negative.
Example
input
6
4 -4 1 -3 1 -3
output
5
问题解析
这题是说有n瓶药,吃了之后会恢复a[i]点生命值或减少a[i]点生命值,你从左往右按顺序吃(也可以选择不吃),问你在生命值不为负的情况下能吃几瓶药。
因为c1和c2仅有数据大小的差异,我就直接按照c2来写,这题可以直接贪心写,把那些小的药水都忽略掉即可。
我们可以准备一个小根堆,从左往右将药剂插入小根堆中,当小根堆总和为负了,就把它最小的元素弹出,直到总和不为负为止,在此过程中维护一下吃下药水数的最大值即可。每次插入和弹出都是logn,所以总复杂度才nlogn。
AC代码
#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
#include<math.h>
#include<set>
#include<numeric>
#include<string>
#include<string.h>
#include<iterator>
#include<map>
#include<unordered_map>
#include<stack>
#include<list>
#include<queue>
#include<iomanip>
#define endl '\n'
#define int ll
typedef long long ll;
typedef unsigned long long ull;
typedef pair<ll, ll>PII;
const int N = 2e5 + 50;
int n, m;
signed main()
{
ios_base::sync_with_stdio(false);
cin.tie(nullptr);
cout.tie(nullptr);
int t;
int n;
cin >> n;
vector<int>v(n);
priority_queue<int,vector<int>,greater<int>>que;
int res = 0,ans=0;
for (int i = 0; i < n; i++)
{
cin >> v[i];
que.push(v[i]);
res += v[i];
while (res < 0)
{
res -= que.top();
que.pop();
}
ans = max(ans, (ll)que.size());
}
cout << ans << endl;
return 0;
}
边栏推荐
- Opencv learning log 27 -- chip positioning
- MySQL import database error [err] 1273 - unknown collation: 'utf8mb4_ 0900_ ai_ ci’
- 读取和保存zarr文件
- Is the sanic asynchronous framework really so strong? Find truth in practice
- [exercise -10] unread messages
- 快速转 TypeScript 指南
- 渗透测试 ( 3 ) --- Metasploit Framework ( MSF )
- 渗透测试 2 --- XSS、CSRF、文件上传、文件包含、反序列化漏洞
- window11 conda安装pytorch过程中遇到的一些问题
- X-forwarded-for details, how to get the client IP
猜你喜欢
Information security - threat detection - detailed design of NAT log access threat detection platform
Analysis of protobuf format of real-time barrage and historical barrage at station B
Penetration test (1) -- necessary tools, navigation
渗透测试 ( 1 ) --- 必备 工具、导航
QT实现窗口置顶、置顶状态切换、多窗口置顶优先关系
The "sneaky" new asteroid will pass the earth safely this week: how to watch it
Suffix expression (greed + thinking)
D - function (HDU - 6546) girls' competition
C language learning notes
Differential (one-dimensional, two-dimensional, three-dimensional) Blue Bridge Cup three body attack
随机推荐
2027. Minimum number of operations to convert strings
[teacher Gao UML software modeling foundation] collection of exercises and answers for level 20 cloud class
860. Lemonade change
[exercise-2] (UVA 712) s-trees
Differential (one-dimensional, two-dimensional, three-dimensional) Blue Bridge Cup three body attack
Analyse du format protobuf du rideau en temps réel et du rideau historique de la station B
Information security - threat detection engine - common rule engine base performance comparison
605. Planting flowers
Penetration test (7) -- vulnerability scanning tool Nessus
pytorch提取骨架(可微)
807. Maintain the urban skyline
力扣:第81场双周赛
Pyside6 signal, slot
1013. Divide the array into three parts equal to and
Advancedinstaller安装包自定义操作打开文件
Codeforces Round #802(Div. 2)A~D
QWidget代码设置样式表探讨
Programmers, what are your skills in code writing?
渗透测试 ( 2 ) --- 渗透测试系统、靶机、GoogleHacking、kali工具
Auto.js入门