目录
题目描述
学校和 yyy 的家之间的距离为 s 米,而 yyy 以 v 米每分钟的速度匀速走向学校。
在上学的路上,yyy 还要额外花费 1010 分钟的时间进行垃圾分类。
学校要求必须在上午 8:008:00 到达,请计算在不迟到的前提下,yyy 最晚能什么时候出门。
由于路途遥远,yyy 可能不得不提前一点出发,但是提前的时间不会超过一天。
输入格式
一行两个正整数 s,v,分别代表路程和速度。
输出格式
输出一个 2424 小时制下的时间,代表 yyy 最晚的出发时间。
输出格式为 HH:MMHH:MM,分别代表该时间的时和分。必须输出两位,不足前面补 00。
输入输出样例
输入 #1复制
100 99
输出 #1复制
07:48
分析:本题的关键就在于分类讨论、对数据的分析处理,理清思路之后还是挺简单的,有一点我之前审题没有审清楚:不仅可以凌晨出发,还可以在头一天的晚上出发。
#include<iostream>
using namespace std;
int main()
{
double s,v;
cin>>s>>v;
double t1=s/v;
int t2=s/v;
//求小数
double t3=t1-t2;
int T=0; //剩余时间
//有小数
if(t3 != 0)
T=7*60+50-t2-1;
//无小数
else
T=7*60+50-t2;
int T1=0,T2=0;
if(T>=0)
{
T1=T%60;
T2=T/60;
}
else
{
T1=60-((-1)*T)%60;
T2=23-(((-1)*T)/60);
}
//输出
if(T1<=9)
{
if(T2<=9){
cout<<"0"<<T2<<":0"<<T1;
}
else
cout<<T2<<":0"<<T1;
}
else
{
if(T2<=9){
cout<<"0"<<T2<<":"<<T1;
}
else
cout<<T2<<":"<<T1;
}
return 0;
}