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: 行车路程的主要内容,如果未能解决你的问题,请参考以下文章

在后台堆栈中保持片段视图运行

移动椭圆的板绘图代码

PAT1028

2D TOOLKIT备忘录

1028.人口普查(PAT)

Twincat 激活配置错误 0x1028 - 无法激活