枚举算法经典日期问题详解java

简介: 枚举算法是我们在日常中使用到的最多的一个算法,它的核心思想就是:枚举所有的可能。 枚举法的本质就是从所有候选答案中去搜索正确的解。

目录
枚举算法
日期问题
枚举思想
具体代码
__

枚举算法
枚举算法是我们在日常中使用到的最多的一个算法,它的核心思想就是:枚举所有的可能。 枚举法的本质就是从所有候选答案中去搜索正确的解。
使用该算法需要满足两个条件:(1)可预先确定候选答案的数量;(2)候选答案的范围在求解之前必须有一个确定的集合。
枚举算法简单粗暴,他暴力的枚举所有可能,尽可能地尝试所有的方法。虽然枚举算法非常暴力,而且速度可能很慢,但确实我们最应该优先考虑的!因为枚举法变成实现最简单,并且得到的结果总是正确的。
日期问题
题目描述
小明正在整理一批历史文献。这些历史文献中出现了很多日期。小明知道这些日期都在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
2003-03-02
枚举思想
日期问题一般思路都是根据我们的尝试枚举判断日期是否合法等,例如月份1-12,日期1-31或闰年的判断等等。重点在于枚举出所有日期的情况去判断,找出正确答案,避免重复枚举或缺项。
具体代码

  1. package Test;
  2. import java.util.Iterator;
  3. import java.util.Scanner;
  4. import java.util.TreeSet;
  5. public class _日期问题 {
  6. public static void main(String[] args) {
  7. Scanner scanner = new Scanner(System.in);
  8. String data = scanner.next();
  9. String[] str = data.split("/");//以字符 ' / ' 分割成字符串数组
  10. TreeSet ans = new TreeSet();//存放正确答案的集合,利用set集合去重
  11. // 01/02/03
  12. //枚举三种情况日/月/年 ,年/月/日,月/日/年
  13. String case1 = f(str[0], str[1], str[2]);
  14. String case2 = f(str[2], str[0], str[1]);
  15. String case3 = f(str[2], str[1], str[0]);
  16. //如果case字符串合法则加入结果集
  17. if (case1.length() > 0)
  18. ans.add(case1);
  19. if (case2.length() > 0)
  20. ans.add(case2);
  21. if (case3.length() > 0)
  22. ans.add(case3);
  23. //遍历输出结果
  24. Iterator iterator = ans.iterator();
  25. for (String anser : ans) {
  26. System.out.println(anser);
  27. }
  28. }
  29. /**
    • 判断是否合法,
    • @param year
    • @param month
    • @param day
    • @return 空字符串"" 表示不合法
  30. */
  31. private static String f(String year, String month, String day) {
  32. int _year = Integer.parseInt(year);
  33. int _month = Integer.parseInt(month);
  34. int _day = Integer.parseInt(day);
  35. if (_year <= 59)//0-59表示2000年以后,要加上2000
  36. _year += 2000;
  37. else //60-99表示1960 - 1999年,加上1900
  38. _year += 1900;
  39. if (_month > 12 || _month < 1)//判断月份是否合法 <1或者>12均不合法
  40. return "";
  41. if (_day > 31 || _day < 1)//判断日期是否合法<1或者>31均不合法
  42. return "";
  43. /**
    • 接下来判断每个月份对应的日期是否合法(前面已经保证月份1-31)
    • 1,3,5,7,8,10,12每个月固定31天,一定合法
    • 因此要判断其他月份的时候是否合法
  44. */
  45. if(_month == 2) {
  46. //闰年>29不合法
  47. if ((_year % 4 == 0 && _year % 100 != 0) || _year % 400 == 0) {
  48. if (_day > 29)
  49. return "";
  50. }
  51. }else {
  52. //其他月份>30不合法
  53. if (_day > 30)
  54. return "";
  55. }
  56. //月份和日期不足10 要补0
  57. if (_month < 10) {
  58. month = "0" + _month;
  59. }
  60. if (_day < 10) {
  61. day = "0" + _day;
  62. }
  63. return _year + "-" + month + "-" + day;
  64. }
  65. }
相关文章
|
1月前
|
前端开发 JavaScript Java
【前端学java】java中的日期操作(13)
【8月更文挑战第10天】java中的日期操作
16 2
【前端学java】java中的日期操作(13)
|
29天前
|
Java
比较两个日期是否相等Java
这篇文章提供了Java中比较两个日期是否相等的两种方法:使用`Calendar`类和`SimpleDateFormat`类来确定两个日期是否为同一天,并附有详细的代码示例和测试结果。
|
1月前
|
Java
Java枚举使用的基本案例
这篇文章是关于Java枚举的基本使用,通过一个指令下发的代码案例,展示了如何定义枚举、使用枚举以及如何通过枚举实现指令的匹配和处理。
|
1月前
|
Java 开发者
在Java编程中,if-else与switch作为核心的条件控制语句,各有千秋。if-else基于条件分支,适用于复杂逻辑;而switch则擅长处理枚举或固定选项列表,提供简洁高效的解决方案
在Java编程中,if-else与switch作为核心的条件控制语句,各有千秋。if-else基于条件分支,适用于复杂逻辑;而switch则擅长处理枚举或固定选项列表,提供简洁高效的解决方案。本文通过技术综述及示例代码,剖析两者在性能上的差异。if-else具有短路特性,但条件增多时JVM会优化提升性能;switch则利用跳转表机制,在处理大量固定选项时表现出色。通过实验对比可见,switch在重复case值处理上通常更快。尽管如此,选择时还需兼顾代码的可读性和维护性。理解这些细节有助于开发者编写出既高效又优雅的Java代码。
24 2
|
1月前
|
算法 Java
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
37 6
|
1月前
|
搜索推荐 算法 Java
经典排序算法之-----选择排序(Java实现)
这篇文章通过Java代码示例详细解释了选择排序算法的实现过程,包括算法的基本思想、核心代码、辅助函数以及测试结果,展示了如何通过选择排序对数组进行升序排列。
经典排序算法之-----选择排序(Java实现)
|
1月前
|
搜索推荐 算法 Java
|
1月前
|
存储 算法 Java
LeetCode经典算法题:打家劫舍java详解
LeetCode经典算法题:打家劫舍java详解
46 2
|
1月前
|
人工智能 算法 Java
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
37 1
|
1月前
|
存储 算法 Java
LeetCode经典算法题:预测赢家+香槟塔java解法
LeetCode经典算法题:预测赢家+香槟塔java解法
35 1