当前位置: 首页 > news >正文

蓝桥杯训练士兵

 

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

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

#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;
}

 

相关文章:

  • 单点登录(SSO)实战:基于Vue与Spring Boot的深度实现
  • 蓝桥复习3(AT240C2 EE2PROM IIC ) 继电器 蜂鸣器 PWM
  • 汇编学习之《push , pop指令》
  • LeetCode 94. 二叉树的中序遍历
  • PUSCH(Physical Uplink Shared Channel,物理上行共享信道)
  • 自动备份文件到服务器,自动备份文件到服务器有哪些方法?
  • SkyWalking+Springboot实战(最详细)
  • mysql 日期时间变成中文显示
  • 如何解决 Hive 在创建 MySQL 表时出现乱码???的问题
  • 堤坝决口快速沉箱,守护生命的抗洪防线|鼎跃安全
  • 《认知觉醒》下篇·第四章第二节“学习专注:深度沉浸是进化双刃剑的安全剑柄” 总结
  • Layui日期选择器的使用逻辑
  • 23种设计模式-结构型模式-装饰
  • 如何在 SwiftUI 视图中使用分页(Paging)机制显示 SwiftData 数据(三)
  • 藏族问候语语料库下载-选取按方言区分类的藏语问候语音频
  • 卷积层里的多输入多输出通道
  • 论文笔记:ASTTN模型
  • LINUX 1
  • [Linux实战] Linux设备树原理与应用详解
  • 并发多线程八股
  • 网站建设评比文章/sq网站推广
  • 做攻略的网站好/百度竞价是什么工作
  • wordpress导航站/免费外链网
  • 太原企业网站模板建站/湖南企业竞价优化服务
  • 有名的室内设计公司/百度手机seo
  • 网站建设定制公司/宣传推广方案