题目描述
学校和 yyy 的家之间的距离为 s 米,而 yyy 以 v 米每分钟的速度匀速走向学校。
在上学的路上,yyy 还要额外花费 10 分钟的时间进行垃圾分类。
学校要求必须在上午 8:00 到达,请计算在不迟到的前提下,yyy 最晚能什么时候出门。
由于路途遥远,yyy 可能不得不提前一点出发,但是提前的时间不会超过一天。
输入格式
一行两个正整数 s,v,分别代表路程和速度。
输出格式
输出一个 24 小时制下的时间,代表 yyy 最晚的出发时间。
输出格式为 HH:MM,分别代表该时间的时和分。必须输出两位,不足前面补 00。
输入输出样例
输入
100 99
输出
07:48
说明/提示
对于 100%的数据,1≤s,v≤。
解题思路
由于涉及时间的计算,而时间为60进制。因此不妨将所有时间转换为分钟后,直接对分钟进行操作,最后再转换为时间即可。
代码
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
int s,v,timeToSchool,totalTime;
int hour,minute;
int remainTime;
cin >> s >> v;
timeToSchool = ((s + v - 1) / v);
totalTime = timeToSchool + 10;
// 不跨天的情况
if(totalTime <= (8 * 60))
{
remainTime = (8 * 60) - totalTime;
hour = int(remainTime / 60);
minute = remainTime % 60;
cout << setw(2) << setfill('0') << hour << ':' << setw(2) << setfill('0') << minute;
}
else
{
remainTime = totalTime - (8 * 60);
remainTime = (24 * 60) - remainTime;
hour = int(remainTime / 60);
minute = remainTime % 60;
cout << setw(2) << setfill('0') << hour << ':' << setw(2) << setfill('0') << minute;
}
}