问题描述
题目翻译:
电梯上一层花费时间为6s,下一层花费时间为4s,每到达一层都会停留5s,给出一段序列,第一个数字代表电梯停的次数,然后依次输入电梯所停楼层。
题目分析
因为每停一次就会花费五秒钟,所以我们将第一个输入的数字N乘以5,先算出停留时间。边输入边计算当前楼层与前一楼层之间的层数差,初始化前一楼层为0。如果差为正,我们将其6加入最终时间;否则4加入最终时间。每输入一个都需要将其更新为前一楼层数。
代码
#include <iostream>
using namespace std;
int main()
{
int n;//序列长度
cin>>n;
int level;//当前层数
int pre = 0,sum = 0;//前一层数,总时长
for(int i = 0;i < n;i++)
{
cin>>level;
if(level - pre > 0)
sum += (level - pre) * 6;
else
sum += (pre - level) * 4;
pre = level;
}
sum += n * 5;
cout<<sum;
return 0;
}
答题用时5min
Q8——finish√