ACM第一次练习—1006G

题意:有一个电梯,向上一层要6s,向下一层要4s,每停一次要5s;输入要停的次数,然后输入每次要停的楼层,电梯按输入顺序运行,电梯从0楼开始运行,计算送完最后一个人所用的时间。

思路:使用vector来存放停的楼层,while循环与if配合实现用时的计算。

感想:这个题是因为开始没有审好题出的错,没有考虑到要在同一楼层停两次的情况。

代码:

#include<iostream>
#include<vector>
using namespace std;
int main()
{
int N,b;
int s[1000],j=0;
s[0]=0;
while(cin>>N)
{
if(N==0)
break;
vector<int>a(N);
int i=1,sum=0;
for(b=0;b<N;b++)
{
cin>>a[b];
}
sum=a[0]*6+5;
N=N-1;
while(N--)
{
if(a[i-1]<a[i])
sum+=(a[i]-a[i-1])*6+5;
else if(a[i-1]>a[i])
sum+=(a[i-1]-a[i])*4+5;
else if(a[i-1]==a[i])
sum+=5;
i++;
}
s[j]=sum;
j++; 
}
if(s[0]!=0)
{
for(b=0;j>0;j--,b++)
{
cout<<s[b]<<endl;
}
}
return 0;
}

你可能感兴趣的:(ACM第一次练习—1006G)