蓝桥杯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的正整数。

理解分析:

        相信对 Java 有一定了解的同学看到时间就能够想到 Java 本身自带的 Date 工具。

        有这种想法的同学相信已经知道该如何入手的,但值得注意的是,虽然题目没有给出来,但是从两次的样例输入和输出,就能够看出,我们需要在接收到毫秒值中减去东八区的时差(既 8小时 * 60分钟 * 60秒 * 1000毫秒 = 28800000 毫秒)。

        到此就万事俱备,只欠东风了。用 setTime 给 Date 对象赋值,并且利用 toString 和 substring 转型、截取到所需要的 HH:MM:SS 形式即可完成本题。


代码示例:

package 历届真题.时间显示;

/**
 *资源限制
 * 时间限制:1.0s   内存限制:256.0MB
 *
 * 【问题描述】
 * 小蓝要和朋友合作开发一个时间显示的网站。在服务器上,
 * 朋友已经获取了当前的时间,用一个整数表示,
 * 值为从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的正整数。
 */

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Date d = new Date();
        Scanner sc=new Scanner(System.in);
        long a=sc.nextLong();
        d.setTime(a-28800000);
        System.out.println(d.toString().substring(11, 20));//第11位到19位为所需输出形式
    }
}

 后记:

        如果您喜欢本作,请别忘记点赞哦 ^ ^

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
第十一蓝桥杯省赛第二场java大学b真题共分为两道编程题和一道综合应用题,以下是真题及解析。 第一题是给定一个字符串,求出字符串中所有数字的总和。首先我们可以使用正则表达式来匹配字符串中的数字,然后将匹配到的数字累加起来即可。可以使用Java中的Pattern和Matcher类来实现正则匹配,具体代码如下: ```java import java.util.regex.*; public class Main { public static void main(String[] args) { String str = "abc123def456ghi789"; int sum = 0; Pattern pattern = Pattern.compile("\\d+"); Matcher matcher = pattern.matcher(str); while(matcher.find()) { sum += Integer.parseInt(matcher.group()); } System.out.println("数字总和为:" + sum); } } ``` 第二题是给定两个字符串,判断第二个字符串是否是第一个字符串的子串。可以使用Java中的contains()方法来判断一个字符串是否包含另一个字符串。具体代码如下: ```java public class Main { public static void main(String[] args) { String str1 = "abcdefg"; String str2 = "cde"; if (str1.contains(str2)) { System.out.println("第二个字符串是第一个字符串的子串!"); } else { System.out.println("第二个字符串不是第一个字符串的子串!"); } } } ``` 综合应用题是实现一个简单的计算器,根据输入的两个数字和运算符进行相应的运算并输出结果。我们可以使用Java中的Scanner类来获取用户输入的数字和运算符,并根据运算符进行相应的运算。具体代码如下: ```java import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.print("请输入第一个数字:"); int num1 = scanner.nextInt(); System.out.print("请输入第二个数字:"); int num2 = scanner.nextInt(); System.out.print("请输入运算符(+、-、*、/):"); String operator = scanner.next(); double result = 0; switch(operator) { case "+": result = num1 + num2; break; case "-": result = num1 - num2; break; case "*": result = num1 * num2; break; case "/": result = num1 / num2; break; default: System.out.println("无效的运算符!"); } System.out.println("计算结果为:" + result); } } ``` 以上就是第十一蓝桥杯省赛第二场java大学b真题及解析的回答,希望能对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值