I
题目描述
yyy 的学校要求早上 8 点前到达。学校到 yyy 的家一共有 s(s≤10000) 米,而 yyy 可以v(v<10000) 米每分钟的速度匀速走到学校。此外在上学路上它还要额外花 10 分钟时间进行垃圾分类。请问为了避免迟到 yyy 最晚什么时候出门?输出 HH:MM 的时间格式,不足两位时补零。由于路途遥远, yyy 可能不得不提前一天出发,不过不可能提前超过一天。
输入格式
两个正整数 s,v,意思已经在题目中给定。
输出格式
hh:mm 表示最晚离开家的时间(时:分,必须输出两位,不足两位前面补0)
输入输出样例
输入 输出
100 99 07:48
首先,先定义两个变量,分别用来表示分和小时。用路程除以速度求出需要走多少分钟,并且加上垃圾分类的时间。(因为除法是自动按整数算的,所以需要特判一下是否需要多余的一分钟)。然后,将分钟换算成小时。这时候判断一下小时数是否大于一天(大于一天就相当于要走一个24小时,可以直接抹掉),或者是否大于8小时且小于24小时(这说明将会需要特殊处理一下,会在前一天出发,但不会走上一天),亦或者是小于8小时(这个直接用8减去t就好)。这时候判断一下,分钟数是否大于0,如果大于0,就需要拿出一小时拆开来减,所以,小时数要减1。输出的是否分别判断一下小时数和分钟数是否小于10,如果小于,则需要在前面补0.
#include<iostream>
using namespace std;