acm 行车路程

问题 P : 行车路程
时间限制:1 秒内存限制:32 兆特殊判题: 否 
标签
模拟
题目描述
小明开车从杭州去上海,但是车上的里程计坏了,无法计算里程了。幸好速度计等其他原件正常,所以小明可以保持恒定的速度行驶,并且可以根据路况调整行车速度。
同时小明身上有一块秒表,并且记录了从出发到每次行车速度改变时所经过的时间。现在小明想知道出发之后的某些时刻他已行驶的路程是多少。
输入格式
输入包含若干行。每行先输入一个从出发开始所经过的时间,格式为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
提示[+]
*** 提示已隐藏,点击上方 [+] 可显示 ***
分类
模拟
//该题的解题思路:
//使用字符数组完成对数据的输入,并对其根据与其减去'0'得到所想得到的数据;
//再判断当前时间已经经过的路程;
//测试其长度,与长度8相比较得出当前阶段是否改变速度;
//第一个输入数据不为长度8,即当前行驶过的路程为0;故前面是设为默认v=0;此处进入判断语句的else中,并将当前时间
//修改为过去时间,此处并将要修改的速度得出,即通过一个for循环;
//在数据为长度8时数据输入时,完成当前时间与过去时间的比较即得出了行驶路程。


#include<iostream>
#include<cstring>      //在使用strlen时使用该函数库;
#include<iomanip>
using namespace std;
int main()
{
int i,h,m,s,l,now=0,time=0;
double lu=0,v=0;//v=0;此处当初写是漏去了,注意。。。
char a[30];
while(gets(a))
{
h=(a[0]-'0')*10+(a[1]-'0');      
m=(a[3]-'0')*10+(a[4]-'0');
s=(a[6]-'0')*10+(a[7]-'0');
now=h*3600+m*60+s;
l=strlen(a);
if(l==8)         //判断输入的数据是否包含行车速度并形成改变
{
lu=lu+(now-time)*v/3600;        
cout<<a<<" "<<fixed<<setprecision(2)<<lu<<" km"<<endl;
time=now;
}
else
{
lu=lu+(now-time)*v/3600;
time=now;
v=a[9]-'0';      
for(i=10;i<l;i++)
  v=v*10+a[i]-'0';  //这里不管是几位都能判断。。当初想多了
}
}
return 0;
}
//总结:对于此题学到的是对于字符的处理与'0'做简单比较,处理好过去时间段与现在时间段的,并对字符数组加深了认识。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值