贪心策略:FatMouse‘ Trade

2024-06-06 19:20
文章标签 贪心 策略 trade fatmouse

本文主要是介绍贪心策略:FatMouse‘ Trade,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

题目描述

FatMouse prepared M pounds of cat food, ready to trade with the cats guarding the warehousecontaining his favorite food, JavaBean.The warehouse has N rooms. The i-th room contains Jfipounds of JavaBeans and requires F[i] pounds of cat food. FatMouse does not have to tradefor all theJavaBeans in the room, instead, he may get /[i]*a% pounds of JavaBeans if he pays Ffi]*a% pounds ofcat food, Here a is a real number, Now he is assigning this homework to you:tell him the maximumamount of JavaBeans he can obtain.

输入

The input consists of multiple test cases. Each test case begins with a line containing two non-negativeintegers M and N. Then N lines follow, each contains two non-negative integers J[i] and Fli]respectively, The last test case is followed by two -1's. All integers are not greater than 1000.

输出

For each test case, print in a single line a real number accurate up to 3 decimal places, which is themaximum amount of JavaBeans that FatMouse can obtain.

样例输入

5 3
7 2
4 3
5 2
20 3
25 18
24 15

15 10
-1 -1

样例输出

13.333
31.500

题目大意

老鼠准备了 M 磅猫粮,并且准备拿这些猫粮和守卫仓库的猫交换自己最爱的咖啡豆(JavaBean)。仓库共有 N个房间,每个房间里面都有咖啡豆。在第i个房间内有 Ji]磅咖啡豆,但相应地需要付出 Fi磅的猫粮才能进行兑换。但是,老鼠并不一定要兑换该房间内全部的咖啡豆;相反,如果老鼠支付 a%*F[]的猫粮,那么可以获得 a%*Л[]的咖啡豆。现在请你告诉它,M磅猫粮最多可以获得多少咖啡豆。

分析

看到这一题,精于计算的读者可能会马上反应过来,这和日常买物品是一样的,每次购买商品的时候,优先挑选剩余物品中性价比(即重量价格之比)最高的物品,直到该物
品被买完或金钱耗尽。

① 若当前性价比最高的物品已被买完,则继续在剩余的物品中寻找性价比最高的物品,并不断重复这个过程。
② 若当前金钱耗尽,则代表交易结束;此时,已经买到了最多的商品,输出这个最优解即可。
本题中,每个房间的咖啡豆(JavaBean)对应于不同的商品,每个房间的 J[i]代表该商品的重量,F[i]代表该商品的价格,老鼠手中的猫粮对应于金钱。

代码

import java.util.Arrays;
import java.util.Scanner;class JavaBean implements Comparable<JavaBean>{double weight;double cost;public JavaBean(double weight,double cost){this.weight = weight;this.cost = cost;}@Overridepublic int compareTo(JavaBean o) {return (int)(this.weight/this.cost - o.weight/o.cost);}
}public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);while(scanner.hasNext()){//M磅猫粮int m = scanner.nextInt();//N个房间int n = scanner.nextInt();if(m == -1 && n == -1){break;}//读取数据JavaBean[] javaBeans = new JavaBean[n];for (int i = 0; i < n; i++) {double weight = scanner.nextDouble();double cost = scanner.nextDouble();JavaBean jb = new JavaBean(weight, cost);javaBeans[i] = jb;}Arrays.sort(javaBeans);float res = 0;for (int i = 0; i < n && m > 0; i++) {if(javaBeans[i].cost < m){res += javaBeans[i].weight;m -= javaBeans[i].cost;}else {res += javaBeans[i].weight * (m / javaBeans[i].cost);break;}}System.out.println(res);}}
}

 

这篇关于贪心策略:FatMouse‘ Trade的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1037001

相关文章

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Redis过期删除机制与内存淘汰策略的解析指南

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

Redis中6种缓存更新策略详解

《Redis中6种缓存更新策略详解》Redis作为一款高性能的内存数据库,已经成为缓存层的首选解决方案,然而,使用缓存时最大的挑战在于保证缓存数据与底层数据源的一致性,本文将介绍Redis中6种缓存更... 目录引言策略一:Cache-Aside(旁路缓存)策略工作原理代码示例优缺点分析适用场景策略二:Re

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解