日期问题和日期常用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
    }
}
相关推荐
hai31524754315 小时前
FlashAttention C语言(C++)实现(展示版)
c语言·开发语言·c++·人工智能·算法
林爷万福15 小时前
光谱数据预处理:基线校正、平滑去噪实战
人工智能·算法
8Qi815 小时前
LeetCode 1049:最后一块石头的重量 II —— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
wubba lubba dub dub75016 小时前
第四十九周学习周报
人工智能·算法·机器学习
Java_2017_csdn16 小时前
ComplexKeysShardingAlgorithm 小结
java·大数据·算法
海梨花16 小时前
快手面试高频算法题
java·算法·面试
lqqjuly16 小时前
超分辨率算法深度解析(Super-Resolution Algorithms)
算法
一切皆是因缘际会17 小时前
AI智能新时代
数据结构·人工智能·ai·架构
嵌入式老牛18 小时前
液晶段码(米/日字格)识别—倾斜校正
opencv·算法·仿射变换
luj_176818 小时前
残熵算法:风险缓冲与效率优化的融合
c语言·开发语言·网络·经验分享·算法