Elevator
题目:
从键盘输入N(电梯停的个数,N<100),接着在一行内输入N个数(每个数代表电梯在这层停)。已知电梯每上升一层需要6秒,下降一层需要4秒,每停一层需要5秒,现在电梯处于第0层,并且电梯可以在完成后不回到0层。要求实现可以多次测试,在显示器上显示出电梯运行一共所需要的时间。
分析:每上升一层则加6,每下降一层则加4,如果层数与输入的数一样则加5。
例如:
输入:12
总的时间sum=6+6+5=(2-0)*6+5=17;
输入:32 3 1
分析:
总的时间sum=6+6+5+6+5+4+4+5=(2-0)*6+5+(3-2)*6+5+(3-1)*4+5=41;
做这道题的时候,真心感到自己的英文很差很差,竟然没有看懂题目,不知道输入的数代表那一层需要停5秒,而我当成每一层都要停5秒,所以怎么提交都不对。所以一定要好好学英语,不然题目都看不懂!!好忧伤~~
代码:
#include<iostream>
using namespace std;
int main(){
int n,a[100]={0},sum=0;
while(cin>>n && n!=0 && n>0){ //输入的n只要不是负数,并且不等于0,那么就继续执行,否则退出
a[0]=0;sum=0;
for(int i=1;i<=n;i++){
cin>>a[i];
if(a[i]>a[i-1]){ //如果后一个数大于前一个数,即电梯上升
sum+=(a[i]-a[i-1])*6+5;
}
else{ //如果后一个数小于前一个数,即电梯下降
sum+=(a[i-1]-a[i])*4+5;
}
}
cout<<sum<<endl;
}
return 0;
}