日期问题和日期常用API

问题描述

小蓝发现了一个神奇的闹钟,从纪元时间(19701970 年 11 月 11 日 00:00:0000:00:00)开始,每经过 xx 分钟,这个闹钟便会触发一次闹铃 (纪元时间也会响铃)。这引起了小蓝的兴趣,他想要好好研究下这个闹钟。

对于给出的任意一个格式为 уууу-MM-ddHH:mm:ssуууу-MM-ddHH:mm:ss 的时间,小蓝想要知道在这个时间点之前 (包含这个时间点) 的最近的一次闹铃时间是哪个时间?

注意,你不必考虑时区问题。

输入格式

输入的第一行包含一个整数 TT,表示每次输入包含 TT 组数据。

接下来依次描述 TT 组数据。

每组数据一行,包含一个时间(格式为 уууу-MM-ddHH:mm:ssуууу-MM-ddHH:mm:ss)和一个整数 xx,其中 xx 表示闹铃时间间隔(单位为分钟)。

输出格式

输出 TT 行,每行包含一个时间(格式为 уууу-MM-ddHH:mm:ssуууу-MM-ddHH:mm:ss),依次表示每组数据的答案。

样例输入

复制代码
2
2016-09-07 18:24:33 10
2037-01-05 01:40:43 30

样例输出

复制代码
2016-09-07 18:20:00
2037-01-05 01:30:00

评测用例规模与约定

对于所有评测用例,1≤T≤10,1≤x≤10001≤T≤10,1≤x≤1000,保证所有的时间格式都是合法的。

java 复制代码
import java.time.Duration;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        DateTimeFormatter df = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
        LocalDateTime epoch = LocalDateTime.of(1970 , 1 , 1 , 0 , 0 ,  0);
        LocalDateTime[] ans = new LocalDateTime[n];
        for (int i = 0; i < n; i++) {
            String s1 = sc.next();
            String s2 = sc.next();
            long x = sc.nextLong();
            LocalDateTime t1 = LocalDateTime.parse(s1 + " " + s2, df);
            long dif = Duration.between(epoch , t1).toMinutes();
            long neart = dif/x*x;
            ans[i] = epoch.plusMinutes(neart);
        }
        for(LocalDateTime t : ans){
            System.out.println(t.format(df));
        }
    }
}

Java 8 日期 API = 不可变类 = 构造私有 = 不能 new = 必须用静态方法(now/of/parse)

还有很多常用的API,比如获取今天是周几,今天是几号,获取时间差

其中获取时间差

2. Period

  • 算时间(时分秒) → 用 Duration
  • 算日期(年月日) → 用 Period
  • 只想拿相差总天数 → 用 ChronoUnit.DAYS.between(最简单)
    1. ChronoUnit(推荐 ✅)
  • 返回总相差数
  • 比如:2 年 3 个月 → YEARS 给你 2,MONTHS 给你 27
  • 简单、直接、适合业务计算
  • 返回分开的年、月、日
  • 比如:2 年 3 个月 5 天
  • 适合展示 "XX 年 XX 月 XX 日
java 复制代码
public class test1 {
    public static void main(String[] args) {
        LocalDate t1 = LocalDate.of(2023 , 2 , 12);
        LocalDate t2 = LocalDate.of(2024 , 2 , 12);
        System.out.println(Period.between(t1 , t2).getDays());  //结果为0
        System.out.println(Period.between(t1 , t2).getMonths());  //结果为0
        System.out.println(Period.between(t1 , t2).getYears());  //结果为1

        System.out.println(ChronoUnit.DAYS.between(t1 , t2));   //结果为365
        System.out.println(ChronoUnit.MONTHS.between(t1 , t2));   //结果为12
        System.out.println(ChronoUnit.YEARS.between(t1 , t2));   //结果为1
    }
}
相关推荐
李伟_Li慢慢9 小时前
wolfram详解山峦算法
前端·算法
counting money9 小时前
prim算法最小生成树(java)
算法
澈2079 小时前
C++面向对象:类与对象核心解析
c++·算法
用户690673881929 小时前
基于无人机的单目测距系统,平均误差仅2.12%
算法
dinl_vin10 小时前
LangChain 系列·(四):RAG 基础——给大模型装上“外脑“
人工智能·算法·langchain
码完就睡10 小时前
数据结构——哈希表原理与C语言实现总结
数据结构·散列表
探物 AI10 小时前
【感知·医学分割】当 YOLOv11 杀入医学赛道:先检测后分割的级联架构
算法·yolo·计算机视觉·架构
隔壁大炮10 小时前
Day06-08.CNN概述介绍
人工智能·pytorch·深度学习·算法·计算机视觉·cnn·numpy
白云千载尽10 小时前
前馈与反馈——经典控制理论中的基础概念
人工智能·算法
炽烈小老头10 小时前
【每日天学习一点算法 2026/04/27】缺失的第一个正数
学习·算法