首页 > 其他分享 >DreamJudge-1478-喝饮料

DreamJudge-1478-喝饮料

时间:2024-06-15 23:24:23浏览次数:23  
标签:Drink int ml drink DreamJudge 饮料 1478 drinks

1.题目描述

Time Limit: 1000 ms
Memory Limit: 256 mb

商店里有n中饮料,第i种饮料有mi毫升,价格为wi。
小明现在手里有x元,他想吃尽量多的饮料,于是向你寻求帮助,怎么样买才能吃的最多。
请注意,每一种饮料都可以只买一部分。

输入输出格式

输入描述:

有多组测试数据。
第一行输入两个非负整数x和n。
接下来n行,每行输入两个整数,分别为mi和wi。
所有数据都不大于1000。
x和n都为-1时程序结束。

输出描述:

请输出小明最多能喝到多少毫升的饮料,结果保留三位小数。

输入输出样例

输入样例#:

233 6
6 1
23 66
32 23
66 66
1 5
8 5
-1 -1

输出样例#:

136.000

题目来源
云南大学机试题

2.题解

2.1 贪心算法

思路

我先开始理解错了题意,以为一种饮料能够购买多次,其实这里只能购买一次!!!
考虑优先购买 ml/价格 性价比最高的饮料, 由于请注意,每一种饮料都可以只买一部分。,保证我们的每一步都是最优解,否则不一定成立!!!

代码

#include<bits/stdc++.h>
using namespace std;
class Drink{
public:
	int m, w;
	Drink(){} 
	Drink(int ml, int price):m(ml), w(price){} 
	bool operator<(const Drink& other)const{
		return other.w * m  > w * other.m;
	}
};
int main(){	
	while(true){
		int n, w;
		cin >> w >> n;
		if(w == -1 && n == -1) break; 
		vector<Drink> drinks(n); // 这里需要初始化空构造函数 
		for(int i = 0; i < n; i++){
			int ml, price;
			cin >> ml >> price;
			drinks[i] = Drink(ml, price);
		}

		sort(drinks.begin(), drinks.end());
		
		double ans = 0;
		for(Drink drink : drinks){
			if(w >= drink.w){
				ans += drink.m;
				w -= drink.w;
			}else{
				ans += static_cast<double>(w) * drink.m / drink.w;
				break;
			}
		}
		printf("%.3lf\n", ans);
	}
	return 0;
} 

标签:Drink,int,ml,drink,DreamJudge,饮料,1478,drinks
From: https://www.cnblogs.com/trmbh12/p/18249969

相关文章

  • DreamJudge-1383-查找第K小的数(待解决)
    1.题目描述?TimeLimit:1000msMemoryLimit:256mb查找一个数组的第K小的数,注意同样大小算一样大。如213452第三小数为3。输入输出格式输入描述:输入有多组数据。每组输入n,然后输入n个整数(1<=n<=1000),再输入k。输出描述:输出第k小的整数。输入输出样例输......
  • DreamJudge-1177-查找学生信息
    1.题目描述TimeLimit:1000msMemoryLimit:32768mb“臭味相投”——这是我们描述朋友时喜欢用的词汇。两个人是朋友通常意味着他们存在着许多共同的兴趣。然而作为一个宅男,你发现自己与他人相互了解的机会并不太多。幸运的是,你意外得到了一份北大图书馆的图书借阅记录,于......
  • DreamJudge-1310-奥运排序问题(精华)
    1.题目描述TimeLimit:1000msMemoryLimit:256mb按要求,给国家进行排名。输入输出格式输入描述:有多组数据。第一行给出国家数N,要求排名的国家数M,国家号从0到N-1。第二行开始的N行给定国家或地区的奥运金牌数,奖牌数,人口数(百万)。接下来一行给出M个国家号。输出描述:......
  • DreamJudge-1248-整数奇偶排序
    1.题目描述TimeLimit:1000msMemoryLimit:256mb输入10个整数,彼此以空格分隔。重新排序以后输出(也按空格分隔),要求:1.先输出其中的奇数,并按从大到小排列;2.然后输出其中的偶数,并按从小到大排列。输入输出格式输入描述:任意排序的10个整数(0~100),彼此以空格分隔。输......
  • DreamJudge-1227-日志排序(精华)
    1.题目介绍TimeLimit:1000msMemoryLimit:256mb有一个网络日志,记录了网络中计算任务的执行情况,每个计算任务对应一条如下形式的日志记录:“hs_10000_p”是计算任务的名称,“2007-01-1719:22:53,315”是计算任务开始执行的时间“年-月-日时:分:秒,毫秒”,“253.035(s)”是......
  • DreamJudge-1217-国名排序
    1.题目描述TimeLimit:1000msMemoryLimit:256mb问题描述:小李在准备明天的广交会,明天有来自世界各国的客房跟他们谈生意,小李要尽快的整理出名单给经理,你能帮他把客户来自的国家按英文字典次序排好吗?例如小李手上有来自加拿大,美国,中国的名单,排好的名单应是美国,加拿......
  • DreamJudge-1159-成绩排序2.0
    1.题目描述TimeLimit:1000msMemoryLimit:32768mb用一维数组存储学号和成绩,然后,按成绩排序输出。输入输出格式输入描述:输入第一行包括一个整数N(1<=N<=100),代表学生的个数。接下来的N行每行包括两个整数p和q,分别代表每个学生的学号和成绩。输出描述:按照学生的成......
  • DreamJudge-1240-首字母大写
    1.题目介绍TimeLimit:1000msMemoryLimit:256mb对一个字符串中的所有单词,如果单词的首字母不是大写字母,则把单词的首字母变成大写字母。在字符串中,单词之间通过空白符分隔,空白符包括:空格('')、制表符('\t')、回车符('\r')、换行符('\n')。输入输出格式输入描述:输......
  • DreamJudge-1012-字符移动
    1.题目描述TimeLimit:1000msMemoryLimit:256mb输入一个字符串,将其中的数字字符移动到非数字字符之后,并保持数字字符和非数字字符输入时的顺序。例如:输入字符串“ab4f35gr#a6”,输出为“abfgr#a4356”。输入输出格式输入描述:输入一行字符串,长度小于100。输出描述:......
  • DreamJudge-1410-打印日期
    1.题目描述TimeLimit:1000msMemoryLimit:256mb给出年分m和一年中的第n天,算出第n天是几月几号。输入输出格式输入描述:输入包括两个整数y(1<=y<=3000),n(1<=n<=366)。输出描述:可能有多组测试数据,对于每组数据,按yyyy-mm-dd的格式将输入中对应的日期打印出来。输......