其他分享
首页 > 其他分享> > 2021-09-18

2021-09-18

作者:互联网

pat 1008 Elevator --java解题
根据题目写一个统计电梯的上下楼时间加上停留的时间:
题意,

  1. 从0层开始;
  2. 每上升一层花费6秒;
  3. 每一次停留花费5秒,
  4. 每下降一层花费4秒;
  5. 最高楼层不超过100层;
  6. 最后一次到达的楼层不需要返回底层;

题意的明面测试数据:
3 2 3 1
输出结果为:
41

import java.util.Scanner;
//本次解题满分
/*
根据输入表示,第1位输入得数字位要上下楼层得次数,
从第2位数字开始到最后一位数才是上下的楼层
如题解释位: 3次上下楼 ,分别到达第2层,第3层,第1层
*/
public class Main{
    public static Scanner scanner = new Scanner(System.in);
    public static void main(String[] args) {
        int num = scanner.nextInt(); //表示上下楼层的次数
        int numberForFloor; //记录楼层间隔数
        int countTime = 0; //统计时间
        if (num!=0) {
            int[] arr = new int[num];// 因为说明了要到的楼层次数
            for (int i = 0; i < arr.length; i++) {
                int current = scanner.nextInt(); //当前
                arr[i] = current;
            }
            countTime += arr[0] * 6 + 5;
            for (int i = 0; i < arr.length - 1; i++) {
                if (arr[i] > arr[i + 1]) {  //如果第一位小于第二位表示在下降
                    numberForFloor = arr[i] - arr[i + 1];
                    countTime += (numberForFloor * 4 + 5);
                } else{
                    numberForFloor = arr[i + 1] - arr[i];
                    countTime += (numberForFloor * 6 + 5);
                }
            }
            System.out.print(countTime);
        }else {
            System.out.print(countTime);
        }
    }
}

标签:arr,countTime,int,18,09,System,楼层,2021,numberForFloor
来源: https://blog.csdn.net/weixin_45505823/article/details/120371721