【洛谷算法题】P5707-上学迟到【入门1顺序结构】

简介: 【洛谷算法题】P5707-上学迟到【入门1顺序结构】

【洛谷算法题】P5707-上学迟到【入门1顺序结构】

🌏题目描述

学校和 yyy 的家之间的距离为 s ss 米,而 yyy 以 v vv 米每分钟的速度匀速走向学校。

在上学的路上,yyy 还要额外花费 10 1010 分钟的时间进行垃圾分类。

学校要求必须在上午 8:00 \textrm{8:00}8:00 到达,请计算在不迟到的前提下,yyy 最晚能什么时候出门。

由于路途遥远,yyy 可能不得不提前一点出发,但是提前的时间不会超过一天。

🌏输入格式

一行两个正整数 s , v s,vs,v,分别代表路程和速度。

🌏输出格式

输出一个 24 2424 小时制下的时间,代表 yyy 最晚的出发时间。

输出格式为 HH:MM \texttt{HH:MM}HH:MM,分别代表该时间的时和分。必须输出两位,不足前面补 0 00

🌏样例 #1

🌙样例输入 #1

100 99

🌙样例输出 #1

07:48

🌏提示

对于 100 % 100\%100% 的数据,1 ≤ s , v ≤ 1 0 4 1 \le s,v \le 10^41s,v104

🌏题解

import java.util.Scanner;
public class P5707 {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        double s = in.nextDouble(), v = in.nextDouble();
        // yyy 走路总共需要花费的时间, 要加上 yyy 进行垃圾分类的 10 分钟
        double t = Math.ceil(s / v) + 10;
        // 时间在 8 小时以内
        if (t <= 60 * 8) {
            // 输出小时
            System.out.printf("%02.0f:",8 - Math.ceil(t / 60));
            // 输出分钟
            if ((60 - t % 60) == 60) { // 整点的情况
                System.out.print("00");
            } else { // 不是整点
                System.out.printf("%02.0f",60 - t % 60);
            }
        // 时间超过 8 小时
        } else {
            // 输出小时
            t = t - 60 * 8;
            System.out.printf("%02.0f:",24 - Math.ceil(t / 60));
            // 输出分钟
            if ((60 - t % 60) == 60) {
                System.out.print("00");
            } else {
                System.out.printf("%02.0f",60 - t % 60);
            }
        }
        in.close();
    }
}

🌏总结

这个题考查我们运用编程语言对时间日期的操作,做时间日期类的题目一定要注意临界条件,比如当分钟达到 60 分时,分钟显示的应该是 00,而不是 60,同时小时要加 1。这里我们用到了数学函数double Math.ceil(double a),这个函数返回一个大于等于 a 的 double 类型的值,相当于对浮点数向上取整。比如Math.ceil(3.01)的结果就是 4.0,也可以将其转换为整数 4。

作者:花无缺(huawuque404.com)

相关文章
|
2月前
|
机器学习/深度学习 人工智能 算法
深度学习入门:理解神经网络与反向传播算法
【9月更文挑战第20天】本文将深入浅出地介绍深度学习中的基石—神经网络,以及背后的魔法—反向传播算法。我们将通过直观的例子和简单的数学公式,带你领略这一技术的魅力。无论你是编程新手,还是有一定基础的开发者,这篇文章都将为你打开深度学习的大门,让你对神经网络的工作原理有一个清晰的认识。
|
18天前
|
算法 测试技术 开发者
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗;代码审查通过检查源代码发现潜在问题,提高代码质量和团队协作效率。本文介绍了一些实用的技巧和工具,帮助开发者提升开发效率。
19 3
|
30天前
|
存储 缓存 算法
如何通过优化算法和代码结构来提升易语言程序的执行效率?
如何通过优化算法和代码结构来提升易语言程序的执行效率?
|
1月前
|
机器学习/深度学习 算法
机器学习入门(三):K近邻算法原理 | KNN算法原理
机器学习入门(三):K近邻算法原理 | KNN算法原理
|
1月前
|
机器学习/深度学习 算法 大数据
机器学习入门:梯度下降算法(下)
机器学习入门:梯度下降算法(下)
|
1月前
|
机器学习/深度学习 算法 API
机器学习入门(五):KNN概述 | K 近邻算法 API,K值选择问题
机器学习入门(五):KNN概述 | K 近邻算法 API,K值选择问题
|
1月前
|
机器学习/深度学习 算法
机器学习入门:梯度下降算法(上)
机器学习入门:梯度下降算法(上)
|
3月前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
180 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
3月前
|
机器学习/深度学习 算法 文件存储
【博士每天一篇文献-算法】 PNN网络启发的神经网络结构搜索算法Progressive neural architecture search
本文提出了一种名为渐进式神经架构搜索(Progressive Neural Architecture Search, PNAS)的方法,它使用顺序模型优化策略和替代模型来逐步搜索并优化卷积神经网络结构,从而提高了搜索效率并减少了训练成本。
55 9
|
4月前
|
机器学习/深度学习 数据采集 人工智能
机器学习算法入门与实践
【7月更文挑战第22天】机器学习算法入门与实践是一个既充满挑战又极具吸引力的过程。通过掌握基础知识、理解常见算法、注重数据预处理和模型选择、持续学习新技术和参与实践项目,你可以逐步提高自己的机器学习技能,并在实际应用中取得优异的成绩。记住,机器学习是一个不断迭代和改进的过程,保持好奇心和耐心,你将在这个领域走得更远。