解题思路:代码都有注释,看注释应该会懂

注意事项:

参考代码:

import java.util.Arrays;
import java.util.Scanner;


public class Main01 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner scanner=new Scanner(System.in);
        double d1=scanner.nextDouble();//二个城市之间的距离
        double c=scanner.nextDouble();//油箱的容量
        double d2=scanner.nextDouble();//每升汽油能行驶的距离
        double p=scanner.nextDouble();//汽油价格
        int n=scanner.nextInt();
        //油价是arr[i][1];
        //距离是arr[i][0];
        double [][]arr=new double[n+1][2];
        arr[0][0]=0;
        arr[0][1]=p;
        for (int i = 1; i < arr.length; i++) {
            arr[i][0]=scanner.nextDouble();
            arr[i][1]=scanner.nextDouble();
        }
        //到达每一站需要多少距离;
        for (int i = 0; i < arr.length; i++) {
            //不等于n也就是要前面的距离减去后面的距离=需要行驶的距离;
            if (i!=n) {
                arr[i][0]=arr[i+1][0]-arr[i][0];
            }
            //如果是最后一站,那么就是终点减去这一战的距离=需要行驶的距离;
            else {
                arr[i][0]=d1-arr[i][0];
            }
        }
        //跑不到下一个加油点
         double money=0;//油钱
        double maxcm=c*d2;//一次加满油的最大距离
        for (int i = 0; i < arr.length; i++) {
            //能不能跑到每一个加油站
            if (arr[i][0]>maxcm) {
                System.out.println("No Solution");
                return;
            }
            
        }
        //如果没有加油站
        if (n==0) {
            money=(d1/d2)*p;
           System.out.println(String.format("%.2f", money));
            return;
        }
        //现在要判断哪一个加油站最便宜,但是第一站是必须要加油的,
        //先找到那一站比第一站便宜,如过没有找到,那就把油加满,看最大距离能跑到那一战,所以在找的同时把距离加上
        //要是第一站最贵,那就少加一点,到下一站加
        //要是第一站最便宜就多加点,加到能到达n个站后,在n个站加
        double sen=0;//油箱剩余的油
        int i=0; //这个是初始加油站,一个不变的值,除非j给到i;
        double sumju=0; //汽车一共行驶的距离
        while (i<n) {
            double ju=0;//车子行驶的距离
            //找每一站的油,看那一战比第一站还要便宜
            //如果第一站没有找到,那么就加上第一站的距离,找下一站,一直找,
            //直到每一站的距离总和>最大距离,那就不找了,j就减去一站,然后减去距离,只能在j站加油,
            //要是找到了,比第一站还要便宜的油价,那么j就是第j站最便宜
            int j;
            for (j = i+1; j <=n;j++) {
                //先加上每一段路的距离和车子行驶的总距离
                ju+=arr[j-1][0];
                sumju+=arr[j-1][0];
                //首先判断那一站油钱最便宜,到了最便宜的油站,那么油钱只算起点到这一战的钱,
                if (arr[i][1]>=arr[j][1]) {
                    //算起点到找到j油站的油钱
                    money+=ju/d2*arr[i][1];
                    //那么此时油箱就为0;
                    sen=0;
                    //如果最便宜的那一站刚刚好是最后一战,那么久算出最后一战的到终点的价钱;
                    if (n==j) {
                        money+=((d1-sumju)/d2-sen)*arr[j][1];
                    }
                    break;
                }
                //接着判断是不是最后一战,怕他是最后一站,但是油钱是起点站最便宜,而最大距离也能到达终点,(之前判定过便宜油价了)
                if (j==n) {
                    //要是最后一战就加上最后一个加油站到终点的距离,然后进行判断能不能到
                    ju+=d1-sumju;
                    //不能到,就算出之前的钱+最后一战到终点的钱
                    if (ju>maxcm) {
                        //到最后一战的距离
                        ju=ju-(d1-sumju);
                        money+=(c-sen)*arr[i][1];
                        sen=c-(ju/d2);
                        money+=((d1-sumju)/d2-sen)*arr[j][1];
                        break;
                        
                    }
                    //能到,那么就直接算出起始站到终点站的钱
                    else {
                        money+=ju/d2*arr[i][1];
                        sen=0;
                        break;
                    }
                    
                }
                //判断一直找不到加油站,但是最大距离到不了终点的情况,那就j-1,距离减去一开始加的距离
                if (maxcm<ju) {
                    j-=1;
                    ju-=arr[j-1][0];
                    money+=(c-sen)*arr[i][1];
                    sen=c-maxcm/d2;
                    break;
                }
            }
            //接着把汽车行驶的站给到起始站;
            i=j;
        }
        System.out.println(String.format("%.2f", money));

    }

}


点赞(0)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论