news 2026/4/23 14:56:05

PAT 1033 To Fill or Not to Fill

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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;}

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 6:52:26

在不确定性中构建防线:全新AI产品的测试策略设计与实践

AI测试的范式转移 随着生成式AI、大语言模型&#xff08;LLM&#xff09;驱动的应用遍地开花&#xff0c;传统软件的“确定性输入-确定性输出”测试范式正遭遇前所未有的冲击。一个全新的AI产品&#xff0c;其核心功能基于概率模型&#xff0c;输出具有非确定性、涌现性、语境…

作者头像 李华
网站建设 2026/4/23 11:15:26

12、深入了解 Drupal 内容创建与管理

深入了解 Drupal 内容创建与管理 1. 内容类型概述 在 Drupal 系统中,文章(Article)与博客文章类似,多个文章可以列在同一页面,最新的通常显示在顶部。文章和博客文章实际上可以一起显示在同一页面上,通常按创建日期排序,最新的显示在最上方。 Drupal 核心默认安装仅启…

作者头像 李华
网站建设 2026/4/23 14:44:53

GPT-SoVITS支持哪些音频格式输入?WAV/MP3/M4A兼容性说明

GPT-SoVITS支持哪些音频格式输入&#xff1f;WAV/MP3/M4A兼容性说明 在语音合成技术飞速发展的今天&#xff0c;个性化音色克隆已不再是遥不可及的科研幻想。像 GPT-SoVITS 这样的开源框架&#xff0c;让普通人仅凭一分钟录音就能“复刻”自己的声音&#xff0c;广泛应用于虚拟…

作者头像 李华
网站建设 2026/4/16 7:03:00

python养老院推荐系统_1w568_pycharm django vue flask

目录已开发项目效果实现截图开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;已开发项目效果实现截图 同行可拿货,招校园代理 python养老院推荐系统_1w568_pycharm django vue flask …

作者头像 李华
网站建设 2026/4/23 14:44:51

38、.NET 文件和目录操作及数据读写全解析

.NET 文件和目录操作及数据读写全解析 在进行文件数据的读写操作之前,我们需要先了解文件和目录的操作支持。相关的类位于 System.IO 命名空间,其中包括代表磁盘文件的 File 类和代表目录(Windows 中称为文件夹)的 Directory 类。 目录操作 Directory 类 :该类提…

作者头像 李华
网站建设 2026/4/23 9:34:10

30、WPF开发工具与资源全解析

WPF开发工具与资源全解析 1. 设计工具 随着WPF的发展,越来越多以设计师为中心的产品涌现。以下是一些流行的XAML设计应用程序: - Expression Blend :这是微软为WPF创建用户界面的设计师推出的主要工具,非常推荐。更多信息可查看: www.microsoft.com/expression/prod…

作者头像 李华