当前位置: 首页 > news >正文

PAT 1033 To Fill or Not to Fill


这一题的大意是从杭州到目的地,让我们找需要花费最少多少钱用于加油。要注意的是在沿途中有加油站,不同加油站的价格也各不相同,油箱中的油有限,我们如何选择加油,能花费最少的达到目的地呢?
这一题要用到贪心,即当我们达到一个站点的时候,我们看如果在这个站点加满油能跑的距离内,有没有比当前站点油价更便宜的加油站,如果有,我们只需要在当前加油站加到能跑到更便宜的油即可,如果没有,那么说明当前的加油站的油就是最便宜的,加满即可。如果最终达到不了终点,那么输出最远能到的距离。最开始油箱为空。
接下来我们就需要分情况讨论了
如果起点没有加油站,那么就直接输出最远距离为0。
如果有加油站,我们就从起点开始按照贪心的思路来加油 即:我们看如果在这个站点加满油能跑的距离内,有没有比当前站点油价更便宜的加油站,如果有,我们只需要在当前加油站加到能跑到更便宜的油即可,如果没有,那么说明当前的加油站的油就是最便宜的,加满即可。
要注意如果,当前的加油站的油就是最便宜,我们不一定非要找下一个站点,可以看是否能通过当前站点直接到终点。(测试点4)
如果在当前站点无法直接到终点,那么我们就看有没有后继加油站,如果有,我们就加满油跑到后继的加油站(必须加满,因为后继的加油站的油价比当前的贵,尽可能少加)
如果没有后继节点,那么我们只能选择从当前节点看能不能跑到终点。如果能输出cost,如果不能输出最大跑的距离。
完整代码如下:

#include<bits/stdc++.h>#include<iostream>usingnamespacestd;//驾驶一个汽车从杭州到其他任意城市是容易//但一个车的油箱容量是有限的//我们不得不找加油站有时//不同的汽油站可能给出不同的价格,//你被要求去设计最便宜的路径去走structnode{intd;doubleprice;}n[505];boolcmp(node a,node b){if(a.d<b.d){returntrue;}elseif(a.d==b.d){if(a.price<b.price){returntrue;}else{returnfalse;}}else{returnfalse;}}intmain(){intCmax;//油箱容量cin>>Cmax;intD;//杭州到目的地的距离//每一单元油能跑的平均距离// 汽油站总共的数量// 下面N个数分别表示 油价和这个停车场距离杭州的距离//cin>>D;intDavg;cin>>Davg;intN;cin>>N;for(inti=0;i<N;i++){cin>>n[i].price>>n[i].d;}sort(n,n+N,cmp);doublemaxdistance=0.00;doublecost=0.00;doublecapcility=0;if(n[0].d!=0){//说明在0点出没有加油站printf("The maximum travel distance = %.2f",maxdistance);return0;}intcur=0;while(cur<N){doubleminn=1e18;intindex=-1;for(inti=cur+1;i<N&&n[i].d<=n[cur].d+Cmax*Davg;i++){//说明i这个节点可用到达if(n[i].price<minn){minn=n[i].price;index=i;}if(n[i].price<n[cur].price){minn=n[i].price;index=i;break;//说明比当前的油价还要低//那么我们就应该先跑到油价最低的位置}}if(minn<n[cur].price){//只需要加能到index站点的油即可doubledistance=n[index].d-n[cur].d;//这是两者的距离doubleqiantity=1.00*distance/Davg;//需要的油量if(capcility>=qiantity){capcility-=qiantity;}else{cost+=(qiantity-capcility)*n[cur].price;//再加这么多油capcility=0;}maxdistance+=distance;}elseif(n[cur].d+Cmax*Davg>=D){//说明我们可用直接跑过去了,不用再找中间点了中间点也起不到减少耗费的作用doubleenddistance=D-n[cur].d;doubleqiantity=1.00*enddistance/Davg;if(capcility>=qiantity){capcility-=qiantity;}else{cost+=(qiantity-capcility)*n[cur].price;//再加这么多油capcility=0;}printf("%.2f",cost);break;}elseif(minn<INT_MAX){//说明存在下一站//我们要在当前站加满油cost+=(Cmax-capcility)*n[cur].price;capcility=max(0.0,Cmax-(1.00*(n[index].d-n[cur].d)/Davg));maxdistance+=n[index].d-n[cur].d;}else{//说明没有下一站可用用来加油了,//必须保证当前加满油看能不能能跑到终点////我们看一下从当前站点到终点站的距离doubleenddistance=D-n[cur].d;doubleqiantity=1.00*enddistance/Davg;if(Cmax*Davg>=D-n[cur].d){//说明加满油能跑到if(capcility>=qiantity){capcility-=qiantity;}else{cost+=(qiantity-capcility)*n[cur].price;//再加这么多油capcility=0;}//说明能到达终点printf("%.2f\n",cost);break;}else{maxdistance=n[cur].d+Cmax*Davg;printf("The maximum travel distance = %.2f\n",maxdistance);break;}}if(index!=-1){cur=index;}}return0;}

总结:这一题是贪心的思路,我们要找到最优的思路,这是这一题的第一大难点,第二大难点就是,我们需要分情况讨论,想好各种情况。
贪心往往也会涉及到排序

http://www.jsqmd.com/news/136502/

相关文章:

  • 可用性测试实操:5个低成本方法,让你快速获取真实用户反馈
  • 27、Windows应用开发:打印控制、GPS定位与Live Tiles使用指南
  • 在不确定性中构建防线:全新AI产品的测试策略设计与实践
  • 28、Windows应用中动态磁贴的创建与实现
  • 语音克隆用于危机应对:GPT-SoVITS快速生成应急广播语音
  • 研发数字化转型怎么实现从经验驱动到数据预言的跃迁?
  • 新手买钓鱼竿怎么选?新手鱼竿买什么牌子好?2025年新手鱼竿推荐性价比高 - 品牌2026
  • 26、XML 数据处理:搜索、导航与序列化全解析
  • JLink下载STM32过程中硬错误处理机制分析
  • 30、Windows 8 应用开发全解析
  • 27、XML 序列化与 LINQ 实战应用
  • 2025年山东威海鱼竿生产厂家名单推荐解析,优质渔具产品选购指南 - 品牌2026
  • 阿里云渠道商:如何快速解决更换阿里云GPU公网IP后出现的网络故障?
  • 28、使用LINQ to SQL进行数据操作
  • python医院问诊挂号处方信息管理系统_e9xw2_pycharm django vue flask
  • 2025年正品十大名牌鱼竿,十大公认耐用正品口碑之选 - 品牌2026
  • 31、创建ASP.NET Web表单:从基础到数据绑定的全面指南
  • UDS 28服务安全访问实战案例:项目应用
  • 2025年国产十大鱼竿排名TOP榜认证!中国鱼竿十大排名,十大良心鱼竿排行 - 品牌2026
  • 29、LINQ to XML与关系数据库操作指南
  • 20、构建媒体查看器:从模型到完整功能的实现
  • python在线小说阅读评分平台_0hxfv含章节_pycharm django vue flask
  • 如何招聘到一个合格的SDET?——面试官视角
  • 项目管理中的风险管理与测试风险识别
  • 33、构建WPF与Windows Forms应用程序指南
  • 从《孙子兵法》看测试策略:知己知彼,百战不殆
  • 21、用形状进行绘图:WPF 2D 绘图基础
  • ARM Cortex-M4 FPU单精度浮点数处理手把手教程
  • 语音克隆与身份认证冲突:GPT-SoVITS可能带来的安全挑战
  • 34、深入探索 Windows Forms 应用程序中的文件操作与树视图事件处理