码迷,mamicode.com
首页 > 其他好文 > 详细

日期问题

时间:2018-03-16 19:39:15      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:oid   java   ret   arraylist   一个   post   []   bool   nbsp   


标题:日期问题

小明正在整理一批历史文献。这些历史文献中出现了很多日期。小明知道这些日期都在1960年1月1日至2059年12月31日。令小明头疼的是,这些日期采用的格式非常不统一,有采用年/月/日的,有采用月/日/年的,还有采用日/月/年的。更加麻烦的是,年份也都省略了前两位,使得文献上的一个日期,存在很多可能的日期与其对应。

比如02/03/04,可能是2002年03月04日、2004年02月03日或2004年03月02日。

给出一个文献上的日期,你能帮助小明判断有哪些可能的日期对其对应吗?

输入
----
一个日期,格式是"AA/BB/CC"。 (0 <= A, B, C <= 9)

输入
----
输出若干个不相同的日期,每个日期一行,格式是"yyyy-MM-dd"。多个日期按从早到晚排列。

样例输入
----
02/03/04

样例输出
----
2002-03-04
2004-02-03
2004-03-02

 

注意点:

  ①年份月份天数要在期限之内

  ②月份所对应的天数不能超过日历上对应的天数

  ③需要判断是否为闰年,2月份是否能够达到29天

  ④需要判断日期是否重复

 

这里闰年判断。。天数判断就不写了,太烦。

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
import java.util.Set;
import java.util.TreeSet;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String[] str = sc.nextLine().split("/");
        Set<String> set = new TreeSet<String>();
        String y1 = "19" + str[0];
        String y2 = "20" + str[0];
        
        String y3 = "19" + str[2];
        String y4 = "20" + str[2];
        
        if(Integer.parseInt(y1) >= 1960 && Integer.parseInt(y1) <= 2059) {
            if(Integer.parseInt(str[1]) >= 1 && Integer.parseInt(str[1]) <= 12
                    && Integer.parseInt(str[2]) >= 0 && Integer.parseInt(str[2]) <= 31)
                set.add(y1 + "-" + str[1] + "-" +  str[2]);
        }
        
        if(Integer.parseInt(y2) >= 1960 && Integer.parseInt(y2) <= 2059) {
            if(Integer.parseInt(str[1]) >= 1 && Integer.parseInt(str[1]) <= 12
                    && Integer.parseInt(str[2]) >= 0 && Integer.parseInt(str[2]) <= 31)
            set.add(y2 + "-" + str[1] + "-" +  str[2]);
        }
        
        if(Integer.parseInt(y3) >= 1960 && Integer.parseInt(y3) <= 2059) {
            if(Integer.parseInt(str[0]) >= 1 && Integer.parseInt(str[0]) <= 12
                    && Integer.parseInt(str[1]) >= 0 && Integer.parseInt(str[1]) <= 31)
            set.add(y3 + "-" + str[0] + "-" +  str[1]);
            if(Integer.parseInt(str[1]) >= 1 && Integer.parseInt(str[1]) <= 12
                    && Integer.parseInt(str[0]) >= 0 && Integer.parseInt(str[0]) <= 31)
            set.add(y3 + "-" + str[1] + "-" +  str[0]);
        }
        
        if(Integer.parseInt(y4) >= 1960 && Integer.parseInt(y4) <= 2059) {
            if(Integer.parseInt(str[0]) >= 1 && Integer.parseInt(str[0]) <= 12
                    && Integer.parseInt(str[1]) >= 0 && Integer.parseInt(str[1]) <= 31)
            set.add(y4 + "-" + str[0] + "-" +  str[1]);
            if(Integer.parseInt(str[1]) >= 1 && Integer.parseInt(str[1]) <= 12
                    && Integer.parseInt(str[0]) >= 0 && Integer.parseInt(str[0]) <= 31)
            set.add(y4 + "-" + str[1] + "-" +  str[0]);
        }
        
        for(String s : set) {
            System.out.println(s);
        }
    }
    private static boolean isLeap(String a) {
        int y = Integer.parseInt(a);
        if((y % 4 == 0 && y % 100 != 0) || y % 400 == 0)
            return true;
        else 
            return false;
    }
}

 

日期问题

标签:oid   java   ret   arraylist   一个   post   []   bool   nbsp   

原文地址:https://www.cnblogs.com/jizhidexiaobai/p/8584156.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!