Problem F: F BUYING FEED

Description

Farmer John needs to travel to town to pick up K (1 <= K <= 100)pounds of feed. Driving D miles with K pounds of feed in his truck costs D*K cents. 
The county feed lot has N (1 <= N <= 100) stores (conveniently numbered 1..N) that sell feed. Each store is located on a segment of the X axis whose length is E (1 <= E <= 350). Store i is at 
location X_i (0 < X_i < E) on the number line and can sell John as much as F_i (1 <= F_i <= 100) pounds of feed at a cost of C_i (1 <= C_i <= 1,000,000) cents per pound. Amazingly, a given point on the X axis might have more than one store. 
Farmer John starts at location 0 on this number line and can drive only in the positive direction, ultimately arriving at location E, with at least K pounds of feed. He can stop at any of the feed stores along the way and buy any amount of feed up to the the store's limit. 
What is the minimum amount Farmer John has to pay to buy and transport the K pounds of feed? Farmer John knows there is a solution. 
Consider a sample where Farmer John needs two pounds of feed from three stores (locations: 1, 3, and 4) on a number line whose range is 0..5: 
0 1 2 3 4 5 
--------------------------------- 
1 1 1 Available pounds of feed 
1 2 2 Cents per pound 
It is best for John to buy one pound of feed from both the second and third stores. He must pay two cents to buy each pound of feed for a total cost of 4. When John travels from 3 to 4 he is moving 1 unit of length and he has 1 pound of feed so he must pay 1*1 = 1 cents. 
When John travels from 4 to 5 he is moving one unit and he has 2 pounds of feed so he must pay 1*2 = 2 cents. The total cost is 4+1+2 = 7 cents.

Input

Line 1: Three space-separated integers: K, E, and N Lines 2…N+1: Line i+1 contains three space-separated integers: Xi Fi Ci

Output

A single integer that is the minimum cost for FJ to buy and transport the feed

Sample Input

2 5 3
3 1 2
4 1 2
1 1 1

Sample Output

7

思路:感觉是dp,但是贪心更好写,更好理解。把每个点运单位物品到终点的花费作为单价,排序。

AC代码:
#include<bits/stdc++.h>
using namespace std;
const int MAX = 1010; struct node{
int xi;
int per;
int w;
}stu[MAX]; int n, e, k;
bool cmp(node a, node b) {//让每个点都买单位数量到终点的价格作为单价排序
return n-a.xi+a.per < n-b.xi+b.per;
} int main() {
while(~scanf("%d%d%d", &k, &e, &n)) {
for(int i = 0; i < n; i++) {
scanf("%d%d%d", &stu[i].xi, &stu[i].w, &stu[i].per);
}
sort(stu, stu+n, cmp);
int sum = 0;//贪心 放包问题
for(int i = 0; i < n; i++) {
if(k >= stu[i].w) {
k -= stu[i].w;
sum += (e-stu[i].xi)*stu[i].w+stu[i].w*stu[i].per;
} else {
sum += (e-stu[i].xi)*k+k*stu[i].per;
k = 0;
}
if(k == 0)
break;
}
printf("%d\n", sum);
}
}
dp思想:dp[i][j]状态为坐标为i,买j的最小花费。需要把所有状态跑一遍。最后结果
就是dp[n][k], 详细过程见注释。
AC代码:

#include<cstdio>
#include<vector>
#include<algorithm>
#include<cstring>
using namespace std;
const int INF = 0x3f3f3f3f;
const int MAX = 200; struct node
{
int w;
int per;
}; int k,e,n;
int dp[400][105];// dp[x][w] 其中x为当前坐标,w为已购买数量
vector<node>edge[400]; int main()
{
while(~scanf("%d %d %d",&k,&e,&n))
{
fill(dp[0], dp[0]+MAX*MAX, INF);
for(int i=0;i<n;i++)
{
int xi;
node temp;
scanf("%d %d %d",&xi,&temp.w,&temp.per);
edge[xi].push_back(temp);//一点可能多商店
}
dp[0][0]=0;//边界 //求每种状态
for(int i=1;i<=e;i++)
{
for(int l=k;l>=0;l--)
{
dp[i][l]=dp[i-1][l];//先继承一下,再去更新
for(int j=0;j<edge[i-1].size();j++)//前面那个点的所有商店,跑一遍
{
int Per=edge[i-1][j].per;//当前单价
int W=edge[i-1][j].w;//当前数量
for(int p=0;p<=W;p++)//购买l和w 以内的 物品 的花费
if(l>=p)
dp[i][l]=min(dp[i][l],dp[i-1][l-p]+p*Per+(e-i+1)*p);
//当前状态的最小花费,要么不买, 要么在前一个的状态中找一个能达到该状态,并且花费小的
}
}
}
printf("%d\n",dp[e][k]);//到达5点,购买k的花费就是答案。
}
return 0;
}

BUYING FEED的更多相关文章

  1. ACM BUYING FEED

    BUYING FEED 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 Farmer John needs to travel to town to pick up ...

  2. 2020: [Usaco2010 Jan]Buying Feed, II

    2020: [Usaco2010 Jan]Buying Feed, II Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 220  Solved: 162[ ...

  3. 洛谷 P2616 [USACO10JAN]购买饲料II Buying Feed, II

    洛谷 P2616 [USACO10JAN]购买饲料II Buying Feed, II https://www.luogu.org/problemnew/show/P2616 题目描述 Farmer ...

  4. USACO Buying Feed, II

    洛谷 P2616 [USACO10JAN]购买饲料II Buying Feed, II 洛谷传送门 JDOJ 2671: USACO 2010 Jan Silver 2.Buying Feed, II ...

  5. 【P2616】 【USACO10JAN】购买饲料II Buying Feed, II

    P2616 [USACO10JAN]购买饲料II Buying Feed, II 题目描述 Farmer John needs to travel to town to pick up K (1 &l ...

  6. 【BZOJ】2020: [Usaco2010 Jan]Buying Feed, II (dp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2020 和背包差不多 同样滚动数组 f[j]表示当前位置j份食物的最小价值 f[j]=min(f[j- ...

  7. Buying Feed, 2010 Nov (单调队列优化DP)

    约翰开车回家,又准备顺路买点饲料了(咦?为啥要说"又"字?)回家的路程一共有 E 公里,这一路上会经过 K 家商店,第 i 家店里有 Fi 吨饲料,售价为每吨 Ci 元.约翰打算买 ...

  8. [河南省ACM省赛-第三届] BUYING FEED (nyoj 248)

    #include<iostream> #include<cstdio> #include<algorithm> #include<cstring> us ...

  9. 【BZOJ2059】Buying Feed 购买饲料

    题面 约翰开车来到镇上,他要带V吨饲料回家.如果他的车上有X吨饲料,每公里就要花费X^2元,开车D公里就需要D* X^2元.约翰可以从N家商店购买饲料,所有商店都在一个坐标轴上,第i家店的位置是Xi, ...

随机推荐

  1. utc时间、本地时间及时间戳转化

    1.时间戳的概念 时间戳的定义请看百科unix时间戳,需要注意的时间戳为当前时刻减去UTC时间(1970.1.1)零点时刻的秒数差,与当前系统所处的时区无关,同一时刻不管在任何时区下得到的时间戳都是一 ...

  2. codeforces 632A A. Grandma Laura and Apples(暴力)

    A. Grandma Laura and Apples time limit per test 1 second memory limit per test 256 megabytes input s ...

  3. 幻想乡三连C:狂飙突进的幻想乡

    题解: 不难发现,对于每一条从$S$到$T$的路径,设其$x.y$的和为$S_x.S_y$,其对答案的贡献是$a\cdot S_x+(1-a)\cdot S_y$,这是一个关于$a$的一次函数.而所有 ...

  4. C#实现根据传入时间段,找出时间段内日期,并生成相对应文件路径

    [1]获取固定日期范围内的所有日期,以数组形式返回 /// <summary>        /// 获取固定日期范围内的所有日期,以数组形式返回        /// </summ ...

  5. CodeForces - 605C 凸包+直线与凸包判交

    题目大意: 要完成两种属性p,q的需求,给定n个双属性物品及其单位个物品中含有的属性,要求选择最少的物品来达成属性需求.(可以选择实数个物品) 题解: 实际上是一种属性混合问题 我们知道对于两种双属性 ...

  6. 一个能获取如果hash或search是中文的内容小例子

    代码: (function () { var url = "http//baidu.com#a=你好&b=world"; var url1 = "http//ba ...

  7. Code:目录

    ylbtech-Code:目录 1.返回顶部 1. https://github.com/   2.返回顶部 1. https://gitee.com 2. 3.返回顶部   4.返回顶部   5.返 ...

  8. 通过pip3安装ipython

    操作系统:Centos7.4:ipython可以用来测试python语句,故需要安装. 首先需要安装epelde的扩展库: easy_install是由PEAK(Python Enterprise A ...

  9. 创建sharepoint网站

    1.首先打开管理中心 输入用户名和密码(默认是本机的管理员名称及密码) 在“应用程序管理”选择“管理WEB应用程序” 新建应用程序 选择一个没有占用的端口,选择允许匿名访问 数据库名称一般为WSS_C ...

  10. 全文检索技术---solr

    1       Solr介绍 1.1   什么是solr Solr 是Apache下的一个顶级开源项目,采用Java开发,它是基于Lucene的全文搜索服务器.Solr可以独立运行在Jetty.Tom ...