传送门

1046 旅行家的预算

1999年NOIP全国联赛普及组NOIP全国联赛提高组

 时间限制: 1 s
 空间限制: 128000 KB
 题目等级 : 黄金 Gold题解
 
题目描述 Description

一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的)。给定两个城市之间的距离D1、汽车油箱的容量C(以升为单位)、每升汽油能行驶的距离D2、出发点每升汽油价格P和沿途油站数N(N可以为零),油站i离出发点的距离Di、每升汽油价格Pi(i=1,2,……N)。计算结果四舍五入至小数点后两位。如果无法到达目的地,则输出“No Solution”。

输入描述 Input Description

第一行D1 C D2 P N

之后N行,每行2个数表示离出发点的距离Di和每升汽油的价格Pi

输出描述 Output Description

最消费用,保留2位小数

样例输入 Sample Input

275.6 11.9 27.4 2.8 2

102.0 2.9

220.0 2.2

样例输出 Sample Output

26.95

数据范围及提示 Data Size & Hint

N<=100

【题目大意】

开车从一个点到另一个点,行驶道路需要耗油,路上有N个加油站,问能否到达和最小花费。

【思路】

贪心

能行驶到比当前油费更少的加油站就开过去,不能则加满油。

如果在当前加满油仍行驶不到下一个加油站则no solution

【code】逼我搜题解

#include<iostream>
#include<cstdio>
using namespace std;
double D1,C,D2,P;
int N;
int now,mgood=;
double d[],p[],over[];
double ans,s;
int main() {
// scanf("%lf%lf%lf%lf%lf",&D1,&C,&D2,&P,&N);
cin>>D1>>C>>D2>>P>>N;
for(int i=; i<=N; i++) {
// scanf("%lf%lf",&d[i],&p[i]);
cin>>d[i]>>p[i];
if(d[i]-d[i-]>C*D2) {
printf("No Solution\n");
return ;
}
}
d[]=;
d[N+]=D1;
p[]=P;
p[N+]=;
while(now!=N+) {
s=;
while(s<=C*D2&&now<=N+&&mgood<=N+&&p[mgood]>=p[now]) {
mgood++;
s=s+d[mgood]-d[mgood-];
}
if(s<C*D2) {
if(over[now]>d[mgood]-d[now]) {
over[mgood]=over[now]-d[mgood]+d[now];
} else {
ans+=(d[mgood]-d[now]-over[now])/D2*p[now];
over[mgood]=;
}
} else {
ans+=(C*D2-over[now])/D2*p[now];
mgood=now+;
over[mgood]=(C*D2)-(d[mgood]-d[now]);
}
now=mgood;
}
// cout<<ans;
printf("%.2lf",ans);
return ;
}

【code2】求助 最后一个点orz

#include<iostream>
#include<cstdio>
using namespace std;
double d[],p[],over[];
int now,k,s;
double ans,D1,C,D2,P,N;
int main() {
cin>>D1>>C>>D2>>P>>N;
for(int i=; i<=N; i++) {
cin>>d[i]>>p[i];
if(d[i]-d[i-]>D2*C) {
printf("No Solution\n");
return ;
}
}
d[]=,p[]=P;
while() {
s=;
for(k=now+; k<=N; k++) {
if(p[k]<p[now]) {
s=k;
break;
}
}
if(!s) {
ans+=(D1-d[now])/D2*p[now];
break;
} else {
ans+=(d[s]-d[now])/D2*p[now];
now=s;
}
}
printf("%.2lf\n",ans);
return ;
}

codevs 1046 旅行家的预算的更多相关文章

  1. 洛谷 1016 / codevs 1046 旅行家的预算

    https://www.luogu.org/problem/show?pid=1016 http://codevs.cn/problem/1046/ 题目描述 Description 一个旅行家想驾驶 ...

  2. 洛谷 P1016 旅行家的预算

    P1016 旅行家的预算 题目OJ链接https://www.luogu.org/problemnew/show/P1016 题目描述一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时 ...

  3. 旅行家的预算(NOIP1999&水题测试2017082301)

    题目链接:旅行家的预算 这题还可以,不算太水. 这题贪心即可. 我们采取如下动作: 如果在装满油的情况下能到达的范围内,没有加油站,则无解. 如果在装满油的情况下能到达的范围内,油价最低的加油站的油价 ...

  4. 蓝桥杯 算法训练 ALGO-15 旅行家的预算

    算法训练 旅行家的预算   时间限制:1.0s   内存限制:256.0MB 问题描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车 ...

  5. P1016 旅行家的预算

    P1016 旅行家的预算 题目描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车油箱的容量C(以升为单位).每升汽油能行驶的距离D2 ...

  6. P1016 旅行家的预算——贪心

    P1016 旅行家的预算 贪心求,在当前点如果能到达距离最近的油价比他小的就直接去油价比他小的, 如果在可行范围内没有比他油价小的,就加满开到可行范围内油价最小的点: 这么做是对的,我不会证明: 还有 ...

  7. [luogu]P1016 旅行家的预算[贪心]

    [luogu]P1016 旅行家的预算 题目描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车油箱的容量C(以升为单位).每升汽油能 ...

  8. 洛谷 P1016 旅行家的预算 模拟+贪心

    目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例 输出样例 说明 思路 AC代码 总结 题面 题目链接 P1016 旅行家的预算 题目描述 一个旅行家想驾驶汽车 ...

  9. 【NOIP1999】【Codevs 1046】旅行家的预算

    http://codevs.cn/problem/1046/ Solution: 贪心,如果当前油价很低,它就比起当前剩余油的价还低就可以替换,并且每次加满,最后把剩的油卖掉即可 油价用单调链表(不知 ...

随机推荐

  1. HashMap 和 Hashtable 的同和不同

    综述 可以直接根据 hashcode 值判断两个对象是否相等吗?肯定是不可以的,因为不同的对象可能会生成相同的 hashcode 值.虽然不能根据 hashcode 值判断两个对象是否相等,但是可以直 ...

  2. UNIX&Linux发展图谱

    来自为知笔记(Wiz)

  3. 关于SharePoint 讨论板的一些知识

    关于SharePoint 讨论板的一些知识         近期公司项目可能要用到讨论板.需求是这种:         怎样在回复中仅仅让查看登陆者和讨论主题公布者的信息.         比方我公布 ...

  4. G - Specialized Four-Digit Numbers(1.5.2)

    Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Submit cid=1006#sta ...

  5. C++ ADO 连接 mysql

    1.安装mysql-5.0.22-win32,mysql-connector-odbc-5.1.12-win32.msi    然后:开始菜单->设置->控制面板->管理工具-> ...

  6. Android调用JNI本地方法跟踪目标代码

    正如Android调用JNI本地方法经过有点改变章所说跟踪代码是可行的,但是跟踪某些代码会出现anr,点击取消,还是不好运,有提高办法吗?回答是有(gdb还没试过,本文只讨论ida). 下面是我使用  ...

  7. kubernetes之故障排查和节点维护(二)

    系列目录 案例现场: 测试环境集群本来正常,突然间歇性地出现服务不能正常访问,过一会儿刷新页面又可以正常访问了.进入到服务所在的pod查看输出日志并没有发现异常.使用kubectl get node命 ...

  8. 关于input:-webkit-autofill样式问题

    最近在整理项目的时候,遇到了一个chrome浏览器自动填充的样式问题, 用户名跟密码的input都设置为透明颜色,但是会变成黄色,打开chrome调试工具,发现有个input:-webkit-auto ...

  9. windows下gVim 中文显示为乱码

    打开vimrc文件,在vim的安装目录下可以找到该文件: 或在windows下是在vim/gvim下输入:edit $vim/_vimrc. 在文件的末尾添加一句 "set fileenco ...

  10. IOS8 通知中心(Notification Center)新特性

     本文转载至 http://blog.csdn.net/jinkaiouyang/article/details/30029441   ios手机apple通知中心notificationCenter ...