zoukankan      html  css  js  c++  java
  • 洛谷P2637第一次,第二次,成交! 模拟?DP?

    今天水来一天,就贴道水吧。。

    原题>>https://www.luogu.org/problem/show?pid=2637<<

    题目描述

    因为奶牛们的节食运动(奶牛还节食?)给农夫JOHN余下了一大批干草无法处理,所以他准备要开一个拍卖会去出售他的干草。他有N(1<=N<=1000)批干草(每批大约100捆)。他的客户有M个(1<=M<=1000),都是和他相邻的农夫。 第I名农夫会告诉农夫JOHN他会为农夫JOHN的每批干草付P_i的钱(1<=P_i<=1,000,000)。每个农夫都想买(也只想买)农夫JOHN的一批草料。 为了确保农夫们不会互相嫉妒,所以农夫JOHN决定要以一个固定的价格出售他的草料。每一个出价比农夫JOHN的要价要高的农夫将会买到草料,余下的将会被拒绝购买:< 请你帮助农夫JOHN找出能让他赚到最多的钱的最低的单批草料的售价。

    输入输出格式

    输入格式:

    • 第一行:两个被空格隔开的整数,N和M * 第二行到第M+1行:第I+1行只包含一个整数:P_i

    输出格式:

    第一行:由空格隔开的两个整数:农夫JOHN能出的每批草料的最低价格,以及他能赚到的最多的钱

    输入输出样例

    输入样例#1:
    5 4
    2
    8
    10
    7
    输出样例#1:
    7 21

    说明

    输入样例解释:

    农夫JOHN有5批草料,4个农夫想要购买。他们出价分别为:每批草料为2,8,10和7。

    输出样例解释:

    农夫JOHN应该把价格设定为7,这样会有3个农夫会付钱买草料,农夫JOHN自己会挣到21的钱。

    这题我是在搜索里找到的。。但其实就是一道模拟水题呀。。

    我的思路就是:先把出价有大到小排一下,然后依次定价,每一次降价刚好会多一个人购买。利润就是一个二次函数(开口向下)所以当找到递减趋势的时候直接打破就行,注意要用一个变量来标记定价哦~~~

    #include<iostream>
    #include<algorithm>
    using namespace std;
    int cmp(int a,int b)
    {
        return a>b;
    }
    int main()
    {
        int n,m,a[1005]={0},mmax;
        int i,j,k,e=1,bj;
        cin>>n>>m;
        for(i=0;i<m;i++)
        {
            cin>>a[i];
        }
        sort(a,a+m,cmp);
        k=a[0];mmax=a[0];
        for(i=1;i<m;i++)
        {
            if(e>n) break;
            e++;
            k=a[i]*e;
            if(k>mmax) 
            {
                mmax=k;bj=a[i];
            }
        }
        cout<<bj<<" "<<mmax<<endl;
    }
  • 相关阅读:
    Error creating bean with name 'eurekaAutoServiceRegistration'
    CentOS 下 安装 nginx 执行配置命令 ./configure 报错
    linux解压war包的命令
    idea中如何将一个普通项目转换为maven项目(或者导入Maven项目后没反应)
    IDEA报 : Lombok Requires Annotation Processing
    IDEA中如何添加RunDashboard
    @Controller 和 @RestController 的区别
    @RequestMapping 和 @GetMapping @PostMapping 区别
    批量提取指定文件夹下的所有文件名称及其路径
    TortoiseSVN的bin目录下面没有svn.exe
  • 原文地址:https://www.cnblogs.com/wsblm/p/7136875.html
Copyright © 2011-2022 走看看