码迷,mamicode.com
首页 > 其他好文 > 详细

洛谷——P1208 [USACO1.3]混合牛奶 Mixing Milk

时间:2017-11-26 13:53:02      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:stream   src   奶牛   char   输入输出格式   不同   bad   mes   并且   

P1208 [USACO1.3]混合牛奶 Mixing Milk

题目描述

由于乳制品产业利润很低,所以降低原材料(牛奶)价格就变得十分重要。帮助Marry乳业找到最优的牛奶采购方案。

Marry乳业从一些奶农手中采购牛奶,并且每一位奶农为乳制品加工企业提供的价格是不同的。此外,就像每头奶牛每天只能挤出固定数量的奶,每位奶农每天能提供的牛奶数量是一定的。每天Marry乳业可以从奶农手中采购到小于或者等于奶农最大产量的整数数量的牛奶。

给出Marry乳业每天对牛奶的需求量,还有每位奶农提供的牛奶单价和产量。计算采购足够数量的牛奶所需的最小花费。

注:每天所有奶农的总产量大于Marry乳业的需求量。

输入输出格式

输入格式:

 

第 1 行共二个数值:N,(0<=N<=2,000,000)是需要牛奶的总数;M,(0<= M<=5,000)是提供牛奶的农民个数。

第 2 到 M+1 行:每行二个整数:Pi 和 Ai。

Pi(0<= Pi<=1,000) 是农民 i 的牛奶的单价。

Ai(0 <= Ai <= 2,000,000)是农民 i 一天能卖给Marry的牛奶制造公司的牛奶数量。

 

输出格式:

 

单独的一行包含单独的一个整数,表示Marry的牛奶制造公司拿到所需的牛奶所要的最小费用。

 

输入输出样例

输入样例#1: 复制
100 5
5 20
9 40
3 10
8 80
6 30
输出样例#1: 复制
630

说明

题目翻译来自NOCOW。

USACO Training Section 1.3

 

 

多重背包 48(RE)

技术分享图片
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 2000100
using namespace std;
int n,m,f[N],p[N],s[N];
int read()
{
    int x=0,f=1; char ch=getchar();
    while(ch<0||ch>9){if(ch==-)f=-1;ch=getchar();}
    while(ch>=0&&ch<=9) x=x*10+ch-0,ch=getchar();
    return x*f;
}
int main()
{
    n=read(),m=read();
    for(int i=1;i<=m;i++)
     p[i]=read(),s[i]=read();
    for(int i=1;i<=n;i++) f[i]=99999;
    for(int i=1;i<=m;i++)
     for(int j=n;j>=0;j--)
      for(int k=0;k<=s[i];k++)
       if(j-k<0) break;
       else f[j]=min(f[j],f[j-k]+k*p[i]);
    printf("%d",f[n]);
    return  0;
}
多重背包

贪心

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 2000100
using namespace std;
int n,m,ans;
int read()
{
    int x=0,f=1; char ch=getchar();
    while(ch<0||ch>9){if(ch==-)f=-1;ch=getchar();}
    while(ch>=0&&ch<=9) x=x*10+ch-0,ch=getchar();
    return x*f;
}
struct Node
{
    int s,p;
}node[N];
int cmp(Node a,Node b)
{return a.p<b.p;}
int main()
{
    n=read(),m=read();
    for(int i=1;i<=m;i++)
     node[i].p=read(),node[i].s=read();
    sort(node+1,node+1+m,cmp);
    for(int i=1;i<=m;i++)
    {
        if(node[i].s<=n) 
         ans+=node[i].s*node[i].p,n-=node[i].s;
        else ans+=node[i].p*n,n=0;
        if(n==0) break;
    }
    printf("%d",ans);
    return  0;
}

 

洛谷——P1208 [USACO1.3]混合牛奶 Mixing Milk

标签:stream   src   奶牛   char   输入输出格式   不同   bad   mes   并且   

原文地址:http://www.cnblogs.com/z360/p/7898638.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!