XYNUOJ 1190 行车路程
2018-03-19 21:32
645 查看
1190: 行车路程
时间限制: 1 Sec 内存限制: 32 MB提交: 25 解决: 12
[提交][状态][讨论版]
题目描述
小明开车从杭州去上海,但是车上的里程计坏了,无法计算里程了。幸好速度计等其他原件正常,所以小明可以保持恒定的速度行驶,并且可以根据路况调整行车速度。同时小明身上有一块秒表,并且记录了从出发到每次行车速度改变时所经过的时间。现在小明想知道出发之后的某些时刻他已行驶的路程是多少。
输入
输入包含若干行。每行先输入一个从出发开始所经过的时间,格式为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
提示
就是一个简单的数学问题,只是需要分类的时候思路清晰点,首先接收数据,数据形式比较复杂,直觉告诉自己应该用字符串来处理,这里还不能用scanf,因为scanf遇见空格自动结束,所以应该用gets,然后用两个变量来记录当前时刻跟前一时刻,一个变量路程,核心思想就是当前时刻的路程等于前一时刻已经走得路程加上当前时刻的速度*(当前时刻时间-前一时刻时间)#include<stdio.h>#include<string.h>
#include<math.h>
int main(){
char str[25];
int time=0;//time记录前一个的时刻
double ans=0,v=0;
while(gets(str)){
int h=(str[0]-'0')*10+(str[1]-'0');
int m=(str[3]-'0')*10+(str[4]-'0');
int s=(str[6]-'0')*10+(str[7]-'0');
int now=h*3600+m*60+s;//当前时刻
int len=strlen(str);
if(len==8){
ans=ans+(now-time)*v/3600;
for(int i=0;i<8;i++){
printf("%c",str[i]);
}
printf(" %.2f km\n",ans);
time=now;
}
else{
ans=ans+(now-time)*v/3600;//加上之前没有被算进去的一部分
time=now;
v=str[9]-'0';
for(int i=10;i<len;i++){
v=v*10+str[i]-'0';
}
}
}
return 0;
}
相关文章推荐
- XYNUOJ 行车路程
- XYNUOJ 1246 repair the wall
- XYNUOJ 词组缩写
- XYNUOJ 迷宫问题
- XYNUOJ 1275: 组合的输出
- XYNUOJ 1913 快速查找素数
- XYNUOJ Six Degrees of Separation
- xynuoj 零用钱 酒馆浪人的博客
- XYNUOJ 第四次比赛 懒省事得小名
- XYNUOJ 1095 折半查找
- xynuoj迷宫问题
- xynuoj 1247 fatmouse'trade
- XYNUOJ 第四次比赛 The Intervals
- XYNUOJ 1106 1107 求最大公约数 求最小公倍数
- xynuoj 幂字符串
- XYNUOJ 习题6-6 杨辉三角
- XYNUOJ 最长公共子序列
- xynuoj 2906 单词排序
- XYNUOJ 1259: 找零钱
- XYNUOJ 问题 B: 彩灯统计