月饼 (25)

时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小)

题目描述

月饼是中国人在中秋佳节时吃的一种传统食品,不同地区有许多不同风味的月饼。现给定所有种类月饼的库存量、总售价、以及市场的最大需求量,请你计算可以获得的最大收益是多少。

注意:销售时允许取出一部分库存。样例给出的情形是这样的:假如我们有3种月饼,其库存量分别为18、15、10万吨,总售价分别为75、72、45亿元。如果市场的最大需求量只有20万吨,那么我们最大收益策略应该是卖出全部15万吨第2种月饼、以及5万吨第3种月饼,获得 72 + 45/2 = 94.5(亿元)。

输入描述:

每个输入包含1个测试用例。每个测试用例先给出一个不超过1000的正整数N表示月饼的种类数、以及不超过500(以万吨为单位)的正整数D表示市场最大需求量。随后一行给出N个正数表示每种月饼的库存量(以万吨为单位);最后一行给出N个正数表示每种月饼的总售价(以亿元为单位)。数字间以空格分隔。

输出描述:

对每组测试用例,在一行中输出最大收益,以亿元为单位并精确到小数点后2位。

输入例子:

3 2018 15 1075 72 45

输出例子:

94.50
 
 
思路分析:
 
1.首先用每种月饼的总售价除以月饼的库存量,得到每种月饼的平均单价,
 
2.根据月饼的单价的降序将月饼进行排序,
 
3.判断单价最高的月饼的库存量是否能够满足市场最大需求量,
 
  ①若满足,则直接用需求量*单价就得出最大收益了,
 
 
    例如输入:
      2   100
      200  300
      400  300
 
    表示共有两种月饼,市场最大需求量为100,
 
    第一种月饼的单价:400/200=2,第二种月饼的单价:300/300=1,
 
    所以首先选择单价为2的月饼,因(市场需求量)100<200(单价最大的月饼的库存量),
 
    则100*2=200就是最大收益。
 
 
  ②否则用需求量减去单价最高的月饼的库存量,得到一个新的需求量,
 
  再判断单价第二大的月饼的库存是否满足需求量,,,
 
  以此递归下去,直至满足市场的需求量为止。
 
    例如输入:
      2   300
      200  300
      400  300
 
    表示共有两种月饼,市场最大需求量为300,
 
    第一种月饼的单价:400/200=2,第二种月饼的单价:300/300=1,
 
    所以首先选择单价为2的月饼,因(市场需求量)300>200(单价最大的月饼的库存量),这种月饼要全部卖出;
 
    需求量=300-200=100;
 
    重复以上步骤,因为100<300,所以收益=100*1=100;
 
    则200*2+100*1=500就是总的最大收益。
 
 
Java 代码如下:
 
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner sca = new Scanner(System.in);
        int n = sca.nextInt();
        int d = sca.nextInt();
        double[] Stock = new double[n];
        double[] price = new double[n];
        double[] Proportion = new double[n];
        double temp;
        double sum = 0;
        for (int i = 0; i < price.length; i++) {
            Stock[i] = sca.nextFloat();
        }
        for (int i = 0; i < price.length; i++) {
            price[i] = sca.nextFloat();
        }
        for (int i = 0; i < Proportion.length; i++) {
            Proportion[i] =price[i]/(Stock[i]*1.000);
        }
        for (int i = 0; i < Proportion.length-1; i++) {
            for (int j = i+1; j < Proportion.length; j++) {
                if(Proportion[i]<Proportion[j]){
                    temp = Proportion[j];
                    Proportion[j] = Proportion[i];
                    Proportion[i] = temp;

                    temp = Stock[j];
                    Stock[j] = Stock[i];
                    Stock[i] = temp;

                    temp = price[j];
                    price[j] = price[i];
                    price[i] = temp;
                }
            }
        }

        for (int i = 0; i < Proportion.length; i++) {
            if(d==0)
                break;
            if(d>=Stock[i]){
                sum+=price[i];
                d-=Stock[i];
            }else{
                sum+=Proportion[i]*1.000*d;
                d=0;
            }
        }
        System.out.println(String.format("%.2f",sum));
    }
}

牛客网 PAT 算法历年真题 1010 : 月饼 (25)的更多相关文章

  1. 牛客网 PAT 算法历年真题 1003: 数素数 (20)

    1003:数素数 (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 令Pi表示第i个素数.现任给两个正整 ...

  2. 牛客网 PAT 算法历年真题 1012 : D进制的A+B (20)

    D进制的A+B (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 输入两个非负10进制整数A和B(< ...

  3. 牛客网 PAT 算法历年真题 1009 : 1019. 数字黑洞 (20)

    1019. 数字黑洞 (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 给定任一个各位数字不完全相同的4 ...

  4. 牛客网 PAT 算法历年真题 1011 : 个位数统计 (15)

    个位数统计 (15) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 给定一个k位整数N = dk-1*10k- ...

  5. 牛客网 PAT 算法历年真题 1008 : 锤子剪刀布 (20)

    锤子剪刀布 (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 大家应该都会玩“锤子剪刀布”的游戏:现给出 ...

  6. 牛客网 PAT 算法历年真题 1002 :数字分类 (20)

    1002 :数字分类 (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 给定一系列正整数,请按要求对数字 ...

  7. 牛客网 PAT 算法历年真题 1001 : A+B和C (15)

    1001 : A+B和C (15) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard 题目描述 给定区间[-2的31次方, 2的31次方]内 ...

  8. 牛客网剑指offer刷题总结

    二维数组中的查找: 题目描述:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 两 ...

  9. 牛客网PAT乙级(Basic Level)真题-组个最小数 (20)

    组个最小数 (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 给定数字0-9各若干个.你可以以任意顺序排 ...

随机推荐

  1. 单源最短路——Dijkstra模板

    算法思想: 类似最小生成树的贪心算法,从起点 v0 每次新拓展一个距离最小的点,再以这个点为中间点,更新起点到其他点的距离. 算法实现: 需要定义两个一维数组:①vis[ i ] 表示是否从源点到顶点 ...

  2. 有了art-template,如有神助

    <div class="form-group col-lg-12"> <label class="control-label col-lg-3 text ...

  3. Pycharm设置去除显示的波浪线

    1.选择文件选择file—Settings,如下图打开setting对话框 2.选择Editur—Color Scheme—General选项,然后选择右边对话框中的Errors and Warnin ...

  4. EditPlus查找替换

    换行符\n,记得选择正则表达式 1]正则表达式应用——替换指定内容到行尾解决:① 在替换对话框,查找内容里输入“abc.*”② 同时勾选“正则表达式”复选框,然后点击“全部替换”按钮其中,符号的含义如 ...

  5. EF延迟加载和懒加载

    EF默认是延迟加载的 延迟加载就是刚开始只会读取当前实体对应表的数据 关联表的数据不会读取 只有下面条件用到了才会再去读取 所以可能会造成N次读取数据库  需要在实体的属性加virtual关键字 延迟 ...

  6. IPC 之 ContentProvider 的使用

    一.概述 ContentProvider 是 Android 中提供的专门用于不同应用间进行数据共享的方式.和 Messenger 一样,ContentProvider 的底层实现同样也是 Binde ...

  7. 力扣(LeetCode)7.整数反转

    给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转. 示例 1: 输入: 123 输出: 321 示例 2: 输入: -123 输出: -321 示例 3: 输入: 120 输出: ...

  8. JNI开发-Java从C/C++获取List集合对象

    NI开发有时需要Java从C/C++获取List对象,此篇主要讲解Java从C/C++获取List<Student>返回值; 1. 定义com.niubashaoye.simple.jni ...

  9. 日志log4cxx 封装、实例讲解、配置文件log4cxx.properties

    日志log4cxx 封装.实例讲解.配置文件log4cxx.properties 1. 日志作用 程序运行过程中,需要记录程序中的运行状况,方便排查问题,记录数据.可以根据日志的记录快速定位错误发生的 ...

  10. JS中UTF-8和UTF-16互转

    1.由于服务端使用的Go,默认是使用UTF-8编码的,而JS默认是Unicode编码的(也就是UTF-16),所以为了字符串编码的一致性,将前端字符串数据编码转换为UTF-8之后再发送给服务端,服务端 ...