第十二届蓝桥杯真题Java B组 【时间显示】

【题目】
小蓝要和朋友合作开发一个时间显示的网站。在服务器上,朋友已经获取了当前的时间,用一个整数表示,值为从 1970 年 1 月 1 日 00:00:00 到当前时刻经过的毫秒数。 现在,小蓝要在客户端显示出这个时间。小蓝不用显示出年月日,只需要显示出时分秒即可,毫秒也不用显示,直接舍去即可。 给定一个用整数表示的时间,请将这个时间对应的时分秒输出。
【输入格式】

输入一行包含一个整数,表示时间。

【输出格式】

输出时分秒表示的当前时间,格式形如 HH:MM:SS,其中 HH 表示时,值为 0 到 23,MM 表示分,值为 0 到 59,SS 表示秒,值为 0 到 59。时、分、秒 不足两位时补前导 0。

【样例输入 1】

46800999

【样例输出 1】

13:00:00
【样例输入 2】

1618708103123

【样例输出 2】

01:08:23

【评测用例规模与约定】

对于所有评测用例,给定的时间为不超过 10^18 的正整数。

思路:因为不用表示毫秒,就将时间/1000得到去除毫秒之后的数字,然后再直接除以时分秒得到结果。

获取时分秒的时候可以通过获取一个数各位上的数的方法来操作。例如:258。百位(2)=258/100。十位(5)=(258%100)/10。个位(8)=(258%100)%10。
完整代码:

import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        long n = new Scanner(System.in).nextLong();
        solve(n);
    }
    private static void solve(long time){
        long temp = time/1000;  //  去除毫秒后的数字
        long hour_div = 60*60;  //  为得到小时的表示形式需要除以的数
        long minute_div = 60;   //  为得到分钟的表示形式需要除以的数
        long hour = temp/hour_div%24;   //  获取小时,%24保证其值在1~23之间
        temp %= hour_div;       //  将小时部分去掉,方便获取分钟
        long minute = temp/minute_div;  //  获取分钟
        temp %= minute_div;     //  剩下的部分就是秒
        long second = temp;
        System.out.printf("%02d:%02d:%02d",hour,minute,second);
        System.out.println();
    }
}
### 第十一届蓝桥杯 B 真题概述 第十一届蓝桥杯 Java B 比赛涵盖了多个编程挑战,旨在测试参赛者的算法思维编码能力。以下是部分代表性题目及其特点: #### 题目一:七段码特殊文字表示法 此题要求使用七段数码管的不同合来创建独特的字符表示方法[^1]。 - **背景**:给定一个由七个独立控制的LED成的显示单元(标记为a至g),需设计一套规则使得某些特定模式下的亮起状态能够代表不同的字符。 - **核心条件**: - 至少有一个LED处于点亮状态; - 所有点亮的LED必须形成连续的一片区域; ```python def is_connected(segments): """ 判断指定的segments列表中的元素是否满足连接性约束 参数: segments (list[str]): 表示哪些线段被激活 ('a'-'g') 返回: bool: 如果这些线段能构成相连图形则返回True, 否则False. """ # 这里应该实现具体的逻辑判断函数体... ``` #### 题目二:跑步训练 这是一道关于时间距离转换的基础计算题,涉及单位换算以及基本的时间处理技巧[^3]。 - **目标**:根据给出的速度持续时间,精确求得运动员完成一定量运动所需的总耗时,并将其转化为更易于理解的形式——即多少分钟。 #### 题目三:纪念日 该问题围绕两个日期间相隔的具体天数展开讨论,特别关注到了历年的变化规律尤其是闰年的影响因素。 - **要点提示**: - 计算从某一年份到另一年份之间的完整年度跨度; - 对于跨越多年的场景,考虑每四年一次的额外一天增加情况; - 特殊情况下还需单独考量首尾两年内部月份差异带来的影响。 #### 题目四:合并检测 本题聚焦于优化资源分配策略,在有限条件下寻求最佳解决方案的过程模拟。 - **情境设定**:假设有固定人数接受某种形式的大规模筛查操作,如何合理安排批次大小才能使整体消耗最小化? ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Easenyang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值