算法入门(1) 7.2
【深基2.例12】上学迟到
题目描述
学校和 yyy 的家之间的距离为 $s$ 米,而 yyy 以 $v$ 米每分钟的速度匀速走向学校。
在上学的路上,yyy 还要额外花费 $10$ 分钟的时间进行垃圾分类。
学校要求必须在上午 $\textrm{8:00}$ 到达,请计算在不迟到的前提下,yyy 最晚能什么时候出门。
由于路途遥远,yyy 可能不得不提前一点出发,但是提前的时间不会超过一天。
输入格式
一行两个正整数 $s,v$,分别代表路程和速度。
输出格式
输出一个 $24$ 小时制下的时间,代表 yyy 最晚的出发时间。
输出格式为 $\texttt{HH:MM}$,分别代表该时间的时和分。必须输出两位,不足前面补 $0$。
样例 #1
样例输入 #1
100 99
样例输出 #1
07:48
提示
对于 $100%$ 的数据,$1 \le s,v \le 10^4$。
题解
此处为我的代码(现在还十分笨拙丑陋,但是我会进步的)
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
int s,v;cin>>s>>v;
int minute = s/v;//需要多少分钟走到学校
if(s%v) minute+=1;//如果有余数则向上取整,加一分钟
int h,m;
m = (110 - minute%60)%60;
if((minute%60)>50)
h = (24+6-minute/60)%24;
else
h = (24+7-minute/60)%24;
if(h>=10&&m>=10) cout<<h<<":"<<m;
else if(h>=10&&m<10) cout<<h<<":0"<<m;
else if(h<10&&m>=10) cout<<"0"<<h<<":"<<m;
else if(h<10&&m<10) cout<<"0"<<h<<":0"<<m;
}
观摩 佬1 demo 所学
//所学:
//1.ceil函数向上取整
//2.%02d两位对齐,不足左边补0
//3.尽量用变量名表示数,以免更改麻烦
//4.用小时计算
#include <iostream>
#include <cstdio>
#include <cmath>
using namespace std;
const int CLK = 24; // 24小时制
const int LMT_H = 8; // 到校小时上限
const int LMT_M = 0; // 到校分钟上限
const int EXT = 10; // 额外消耗分钟数
int main() {
int s, v;
cin >> s >> v;
int costM = ceil(1.0 * s / v) + EXT; // 计算消耗分钟
int costH = ceil(1.0 * costM / 60); // 计算消耗小时
costM %= 60; // 保留60进制下的分钟部分
printf("%02d:%02d", (LMT_H - costH + CLK) % CLK, (LMT_M - costM + 60) % 60); // 输出结果
return 0;
}