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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了洛谷——P1208 [USACO1.3]混合牛奶 Mixing Milk相关的知识,希望对你有一定的参考价值。

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的主要内容,如果未能解决你的问题,请参考以下文章

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

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

Luogu P1208 [USACO1.3]混合牛奶 Mixing Milk(贪心)

luogu P1208 混合牛奶 贪心

洛谷P1211 [USACO1.3]牛式 Prime Cryptarithm

l洛谷——P1211 [USACO1.3]牛式 Prime Cryptarithm