题目描述
学校和 yyy 的家之间的距离为 s s s 米,而 yyy 以 v v v 米每分钟的速度匀速走向学校。
在上学的路上,yyy 还要额外花费 10 10 10 分钟的时间进行垃圾分类。
学校要求必须在上午 8:00 \textrm{8:00} 8:00 到达,请计算在不迟到的前提下,yyy 最晚能什么时候出门。
由于路途遥远,yyy 可能不得不提前一点出发,但是提前的时间不会超过一天。
输入格式
一行两个正整数 s , v s,v s,v,分别代表路程和速度。
输出格式
输出一个 24 24 24 小时制下的时间,代表 yyy 最晚的出发时间。
输出格式为 HH:MM \texttt{HH:MM} HH:MM,分别代表该时间的时和分。必须输出两位,不足前面补 0 0 0。
样例 #1
样例输入 #1
100 99
样例输出 #1
07:48
提示
对于 100 % 100\% 100% 的数据, 1 ≤ s , v ≤ 1 0 4 1 \le s,v \le 10^4 1≤s,v≤104。
坑:
- 不超过24h,意味着有可能出发时间是前一天
- 输出字符的限制,可以用过选择条件进行输出
题解
#include <iostream>
using namespace std;
#include<math.h>
#include<string>
#include<algorithm>
#include<iomanip>
int main(){
int s, v;
cin>>s>>v;
double t1 = s/v;
if (s%v != 0){
t1 += 1;
}
int total_min = 24*60;//24h的总分钟数
int left_min = total_min - t1 - 10;
int H = left_min/60;
int M = left_min%60;
H = (8 + H)%24;
if (M >=0 && M <= 9){
if( H >=0 && H <= 9 )
cout<<'0'<<H<<":"<<'0'<<M;
else{
cout<<H<<":"<<'0'<<M;
}
}
else{
if( H >=0 && H <= 9 )
cout<<'0'<<H<<":"<<M;
else{
cout<<H<<":"<<M;
}
}
}