首页 > 代码库 > 【TK】1028: 行车路程
【TK】1028: 行车路程
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 }
【TK】1028: 行车路程
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。