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. Android之Widget学习总结

    1.Widget设计步骤 需要修改三个XML,一个class: 1)第一个xml是布局XML文件(如:main.xml),是这个widget的.一般来说如果用这个部件显示时间,那就只在这个布局XML中 ...

  2. 机器学习 Generative Learning Algorithm (A)

    引言 前面几讲,我们主要探讨了如何对 p(y|x;θ) (即y 相对于x的条件概率)进行建模的几种学习算法,比如,logistic regression 对 p(y|x;θ) 进行建模的假设函数为 h ...

  3. tbody scroll

    http://jsfiddle.net/hashem/CrSpu/555/

  4. 2.2synchronized同步语句块

    使用synchronized虽然能够避免不同步的现象出现,但是也会出现弊端,比如代码执行时间过长,那么其他线程就必须等待该线程执行完毕释放锁之后才能拿到锁. 面对这种问题可以使用同步代码块来解决. 2 ...

  5. 常用排序算法总结(C语言描述)

    最近又把排序给复(yu)习(xi)了一遍,在此总结一下~具体理论思想持续补充完善中... 1.交换排序 (1)普通冒泡 时间复杂度:最差.平均都是O(n^2),最好是O(n) 空间复杂度:O(1) # ...

  6. MongoDB分析工具之一:explain()语句分析工具

    explain(),语句分析工具 MongoDB 3.0之后,explain的返回与使用方法与之前版本有了很大的变化,介于3.0之后的优秀特色和我们目前所使用给的是3.0.7版本,本文仅针对Mongo ...

  7. tomcat部署虚拟主机-搭建两个应用以及httpd和Nginx的反向代理

    实验环境:CentOS7 前提:已经安装好tomcat,未安装请查看http://www.cnblogs.com/wzhuo/p/7111135.html: 目的:基于主机名访问两个应用: [root ...

  8. Ruby 局部变量做block参数

    Ruby中使用yield语句调用block时可以带有参数,参数值见传送个相关联的block.如果传给block的参数是已经存在的局部变量,那么这些变量即为block的参数,他们的值可能会因block的 ...

  9. <c和指针>学习笔记5动态内存分配和预处理器

    1 动态内存 比如声明数组得时候,我们需要提前预估数组长度,分配大了浪费,少了就更不好操作了.从而引入动态分配,需要的时候再分配. (1)malloc和free void *malloc(size_t ...

  10. eos命令

    ps -ef|grep javakill -9 端口号cd /opt/sudytrue>nohup.outnohup eos7.5/startServer.sh &