TK1028: 行车路程
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了TK1028: 行车路程相关的知识,希望对你有一定的参考价值。
1028: 行车路程
时间限制: 1 Sec 内存限制: 32 MB提交: 721 解决: 314
[提交][状态][下载(1元)]
题目描述
小明开车从杭州去上海,但是车上的里程计坏了,无法计算里程了。幸好速度计等其他原件正常,所以小明可以保持恒定的速度行驶,并且可以根据路况调整行车速度。
同时小明身上有一块秒表,并且记录了从出发到每次行车速度改变时所经过的时间。现在小明想知道出发之后的某些时刻他已行驶的路程是多少。
同时小明身上有一块秒表,并且记录了从出发到每次行车速度改变时所经过的时间。现在小明想知道出发之后的某些时刻他已行驶的路程是多少。
输入
输入包含若干行。每行先输入一个从出发开始所经过的时间,格式为hh:mm:ss,如果此时汽车速度改变了,则在时间之后空一格输入一个正整数,表示新的速度,单位为km/h。
行程最开始时汽车是静止的,输入中的时间保证是按照非递减顺序给出的,每个时刻至多只有一次速度改变。
行程最开始时汽车是静止的,输入中的时间保证是按照非递减顺序给出的,每个时刻至多只有一次速度改变。
输出
对于每组输入,输出每个查询(输入中没有速度改变的那些行就是查询)的时间和此时已经经过的路程,具体格式见输出样例。
样例输入
00:00:01 100
00:15:01
00:30:01
01:00:01 50
03:00:01
03:00:05 140
样例输出
00:15:01 25.00 km
00:30:01 50.00 km
03:00:01 200.00 km
1 #include <iostream> 2 #include <cstdio> 3 #include<algorithm> 4 #include<cstring> 5 using namespace std; 6 int main() 7 { 8 char s[100]; 9 int hh,mm,ss,now=0,t=0; 10 double d=0,v=0; 11 12 while(gets(s)) 13 { 14 hh=10*(s[0]-‘0‘)+(s[1]-‘0‘); 15 mm=10*(s[3]-‘0‘)+(s[4]-‘0‘); 16 ss=10*(s[6]-‘0‘)+(s[7]-‘0‘); 17 now=hh*3600+mm*60+ss;/*将hhmmss字符串分开化为h,m,s再化为秒*/ 18 int l=strlen(s); 19 if(l==8)/*/在数据为长度8时数据输入时,完成当前时间与过去时间的比较即得出了行驶路程*/ 20 { 21 d+=(now-t)*v/3600;/*将秒化为小时,因为单位是km/h*/ 22 printf("%s %.2f km\n",s,d); 23 t=now; 24 } 25 else/*速度改变时*/ 26 { 27 d+=(now-t)*v/3600; 28 t=now; 29 v=s[9]-‘0‘;/*注意数组下标从0开始*/ 30 31 /*获取速度,速度存在于字符串第9位开头*/ 32 for(int j=10;j<l;j++) 33 { 34 v=v*10+s[j]-‘0‘;/*不管是几位都能判断,eg:速度105km/h, 35 a[9]=‘1‘,a[10]=‘0‘,a[11]=‘5‘,把字符转化为数字, 36 需要-‘0‘;v=0*10+1=1——1*10+0=10——10*10+5*/ 37 } 38 } 39 } 40 return 0; 41 }
以上是关于TK1028: 行车路程的主要内容,如果未能解决你的问题,请参考以下文章