问题描述
我们城市最高的建筑只有一部电梯。请求列表由N个正数组成。数字表示电梯将以指定顺序停在哪些楼层。将电梯向上移动一层需要6秒钟,向下移动一层楼需要4秒钟。电梯将在每个站点停留5秒钟。
对于给定的请求列表,您将计算在列表上完成请求所花费的总时间。电梯在开始时位于0楼,并且在满足要求时不必返回底层。
输入
有多个测试用例。每个案例包含一个正整数N,后跟N个正数。输入中的所有数字都小于100. N = 0的测试用例表示输入结束。不处理此测试用例。
输出
为每个测试用例打印一行的总时间。
样本输入
1 2
3 2 3 1
0
样本输出
17
41
#include <iostream>
#include <stdio.h>
using namespace std;
int main()
{
int m,n,a,sum,i;
while(scanf("%d",&a)!=EOF)
{
if(a==0)break;
i=a;
n=0;
sum=0;//使得sum初始值为0
while(i--)
{
scanf("%d",&m);
if(m>n)
{
sum=sum+(m-n)*6+5;
n=m;
}
else
{
sum=sum+(n-m)*4+5;
n=m;
}
}
printf("%d\n",sum);
}
return 0;
}