2021-09-18
作者:互联网
pat 1008 Elevator --java解题
根据题目写一个统计电梯的上下楼时间加上停留的时间:
题意,
- 从0层开始;
- 每上升一层花费6秒;
- 每一次停留花费5秒,
- 每下降一层花费4秒;
- 最高楼层不超过100层;
- 最后一次到达的楼层不需要返回底层;
题意的明面测试数据:
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