#include<iostream>
#include<algorithm>
#include<iomanip>
using namespace std;
struct SCoin
{
int m, v;
}coin[101];
int N, T, t;
double V;
bool myCompare(const SCoin& first, const SCoin& second)
{
return first.v * second.m > second.v * first.m;
}
int main()
{
cin >> N >> T;
for (int i = 0; i < N; i++)
cin >> coin[i].m >> coin[i].v;
sort(coin, coin + N, myCompare);
for (int i = 0; i < N; i++)
{
if (T >= t + coin[i].m)
{
V += coin[i].v;
t += coin[i].m;
}
else
{
V += (T - t) * (coin[i].v * 1.0) / (coin[i].m * 1.0);
break;
}
}
cout << fixed << setprecision(2) << V;
return 0;
}
洛谷P2240 【深基12.例1】部分背包问题进阶解法
最新推荐文章于 2025-09-04 22:25:44 发布
这篇博客介绍了一种优化算法,用于在有限时间内最大化价值收益。通过比较硬币的价值和面额,利用自定义比较函数myCompare对硬币进行排序,实现动态调整购买策略。核心内容涉及排序、贪心算法和资源分配。
部署运行你感兴趣的模型镜像
您可能感兴趣的与本文相关的镜像
ACE-Step
音乐合成
ACE-Step
ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言
657

被折叠的 条评论
为什么被折叠?



