蓝桥杯训练士兵

思路:其实每次就是要比较士兵单独训练的价格之和SUM与S的大小,如果 SUM大,那么就减去所有士兵都要训练的次数的最小值,SUM再更新一下,继续比较。

先对士兵的次数按从小到大的次序排序(很重要),再一次遍历士兵,如果遍历到该士兵时,sum>s,那么费用加上所有士兵共同训练的次数*s,由于当前士兵已经结束了,所以sum-=a[i].p;同时共同训练的次数t+=a[i].c;这是为了确保可以算出之后的士兵还要进行多少次的独自训练。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=1e5+5;
int n,s,sum=0,ans=0,t=0;
struct node{
	int p;
	int c;
}a[N];
bool cmp(node a,node b)
{
	return a.c<b.c;
}

signed main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	cin>>n>>s;
	for(int i=0;i<n;i++)
	{
		cin>>a[i].p>>a[i].c;
		sum+=a[i].p;
	}
	sort(a,a+n,cmp);
	for(int i=0;i<n;i++)
	{
		if(sum>s)
		{
			ans+=s*(a[i].c-t);
			t+=a[i].c;
			sum-=a[i].p;
			//ans+=(a[i].c-t)*a[i].p;
		}
		else{
			ans+=(a[i].c-t)*a[i].p;
		}
	}
	cout<<ans<<endl;
	return 0;
}
相关推荐
元亓亓亓8 小时前
LeetCode热题100--169. 多数元素--简单
算法·leetcode·职场和发展
代码无bug抓狂人8 小时前
C语言之产值调整(蓝桥杯省B)
c语言·开发语言·蓝桥杯
闻缺陷则喜何志丹11 小时前
P8699 [蓝桥杯 2019 国 B] 排列数|普及+
c++·数学·蓝桥杯·数论·洛谷·数列
芝士爱知识a17 小时前
2026年AI面试软件推荐
人工智能·面试·职场和发展·大模型·ai教育·考公·智蛙面试
石去皿19 小时前
大模型面试通关指南:28道高频考题深度解析与实战要点
人工智能·python·面试·职场和发展
程序员辣条19 小时前
AI产品经理:2024年职场发展的新机遇
人工智能·学习·职场和发展·产品经理·大模型学习·大模型入门·大模型教程
AI大模型测试19 小时前
大龄程序员想转行到AI大模型,好转吗?
人工智能·深度学习·机器学习·ai·语言模型·职场和发展·大模型
美团程序员19 小时前
80道经典常见测试面试题
软件测试·面试·职场和发展·软件测试面试
sunguang201819 小时前
“懂不懂管理,一看便知”:做管理就是3件事,抓大、放小、管细做管理,其实就是要做好三件事:抓大、放小、管细。
经验分享·职场和发展
ProcessOn官方账号19 小时前
程序员如何与同龄人拉开差距?这5张让你快速提升认知,打开格局!
深度学习·职场和发展·学习方法