顺子日期(结果填空)

2024-04-07 05:12
文章标签 日期 填空 顺子

本文主要是介绍顺子日期(结果填空),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为了解决这个问题,我们需要遍历2022年的每一天,并检查日期的每一位数字以查找顺子。下面是一个Java程序,用于计算2022年中的顺子日期数量:

public class Main {public static void main(String[] args) {int count = 0;  for (int day = 1; day <= 365; day++) {  String date = String.format("%d22%02d%02d", 20, 1 + (day - 1) / 31, (day - 1) % 31 + 1);  System.out.print(date.toString());if (isShunziDate(date)) {  count++;  }  }  System.out.println("Total shunzi dates in 2022: " + count);  }  private static boolean isShunziDate(String date) {  for (int i = 0; i <= date.length() - 3; i++) {  int first = date.charAt(i) - '0';  int second = date.charAt(i + 1) - '0';  int third = date.charAt(i + 2) - '0';  if (second == first + 1 && third == second + 1) {  return true;  }  }  return false;  }    
}

在上面的代码中,isShunziDate 方法检查给定的日期字符串是否包含顺子。我们遍历日期字符串的每一位,并检查当前位、下一位和再下一位是否构成顺子(即当前位+1等于下一位,下一位+1等于再下一位)。

main 方法则遍历2022年的每一天,构造出对应的日期字符串,并调用 isShunziDate 方法来检查。如果某一天的日期字符串包含顺子,则将计数器 count 增加1。

最后,程序输出2022年中顺子日期的总数。

请注意,这个程序假设2022年每个月的天数是固定的(即1月31天,2月28天,3月31天等),这在通常情况下是成立的,因为2022年不是闰年。如果需要更精确的处理(例如,考虑闰年2月有29天的情况),可以改用java.time包中的LocalDate类来生成日期。

运行上述程序,你将得到2022年中顺子日期的总数。你只需要提交这个整数作为答案即可。


解释String date = String.format("%d022%02d%02d", 20, 1 + (day - 1) / 31, (day - 1) % 31 + 1);

这行代码用于生成一个形如 2022MMDD 的日期字符串,其中 MM 代表月份,DD 代表日。这行代码是为了遍历2022年的每一天,而不仅仅是考虑每个月的实际天数。

具体来说,String.format 是一个用于格式化字符串的方法。在这个例子中,它使用三个参数来生成一个字符串。

  1. "%d22%02d%02d" 是格式字符串。

    • %d 表示一个整数,会替换为后面提供的参数。
    • 22 是字面量,直接包含在结果字符串中。
    • %02d 表示一个至少两位的整数,不足两位时前面用0填充。
  2. 20 是第一个 %d 的替换值,因此它会直接输出为 20

  3. 1 + (day - 1) / 31 用于计算月份。

    • day - 1 是当前循环的索引(从0开始),减1是为了从1开始计数。
    • (day - 1) / 31 实际上是将天数除以31(一个月的最大天数),从而得到月份。这里假设每个月都是31天,这在实际情况中是不准确的,但在这个特定问题中,我们只需要一个从1到12的连续数字来表示月份,因此这个简化是可行的。
    • 1 + ... 是因为我们需要从1开始计数月份,而不是从0开始。
  4. (day - 1) % 31 + 1 用于计算日期。

    • (day - 1) % 31 使用模运算(取余)来得到当前天在“当前月”(实际上是按31天一个周期计算的)中的位置。
    • + 1 是为了从1开始计数日期,而不是从0开始。

因此,这行代码为2022年的每一天生成一个字符串,即使它不是按照实际的月份天数来生成的。例如,当 day 为32时,生成的日期字符串将是 20220201,尽管在现实中2月并没有32天。但是,由于我们只关心顺子的存在性,而不是日期的实际有效性,这种简化是允许的。

这篇关于顺子日期(结果填空)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/881714

相关文章

Python使用date模块进行日期处理的终极指南

《Python使用date模块进行日期处理的终极指南》在处理与时间相关的数据时,Python的date模块是开发者最趁手的工具之一,本文将用通俗的语言,结合真实案例,带您掌握date模块的六大核心功能... 目录引言一、date模块的核心功能1.1 日期表示1.2 日期计算1.3 日期比较二、六大常用方法详

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

springboot日期格式化全局LocalDateTime详解

《springboot日期格式化全局LocalDateTime详解》文章主要分析了SpringBoot中ObjectMapper对象的序列化和反序列化过程,并具体探讨了日期格式化问题,通过分析Spri... 目录分析ObjectMapper与jsonSerializer结论自定义日期格式(全局)扩展利用配置

对postgresql日期和时间的比较

《对postgresql日期和时间的比较》文章介绍了在数据库中处理日期和时间类型时的一些注意事项,包括如何将字符串转换为日期或时间类型,以及在比较时自动转换的情况,作者建议在使用数据库时,根据具体情况... 目录PostgreSQL日期和时间比较DB里保存到时分秒,需要和年月日比较db里存储date或者ti

javaScript日期相加减例子

当前时间加上2天 var d = new Date(“2015-7-31”); d.setDate(d.getDate()+2); var addTwo=d.getFullYear()+”年”+(d.getMonth()+1)+”月”+d.getDate()+”日”; “控制台输出===============”+”当前日期加2天:”+addTwo; 使用这种方法,月份也会给你计算.

linux下修改系统日期与时间

cp /usr/share/zoneinfo/Asia/Shanghai  /etc/localtime

时间日期与时间戳转换(Linux C)

本文主要学习三个知识点,第一是UTC时间、GMT时间的概念;第二是在Unix环境下UTC时间与时间戳的转换;第三是在C语言中如何修改时区。 本文参考了《UNP》以及 http://blog.csdn.net/foxir/article/details/43916601 http://blog.csdn.net/ljafl9988/article/details/16847935 一、

Java中计算两个日期间隔多少天

String dbtime1 = "2017-02-23";  //第二个日期 String dbtime2 = "2017-02-22";  //第一个日期 //算两个日期间隔多少天 SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); Date date1 = format.parse(dbtime1); Date dat

实现日期往前或往后或跳转到指定月份或天数

//月份跳转 //初始日期 String yearMonth = "201702"; String yearMonthStr = ""; //往前(负数)或往后(正数) int add = -2; SimpleDateFormat sdf = new SimpleDateFormat("yyyyMM"); Date source = sdf.parse(yearMonth); Cal

Java:日期类2

SimpleDateFormat日期格式化类 构造 SimpleDateFormat(String pattern); pattern是我们自己制定的日期格式,字母不能改变,但连接符可以改变 yyyy--MM--dd--HH 时间单位字母表示 Y年M月d日H时m分s秒 方法 String format(Date date)将Date对象按照对应格式转成String Date par