news 2026/5/1 6:11:38

日期题模版(made by yyf)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
日期题模版(made by yyf)

日期题通常包括:判断是否为闰年,计算某年某月有多少天,日期自增,遍历日期等,这里给出总结

判断是否为闰年

首先什么是闰年,闰年具有哪些特征?如果是整百年(如2000,1700)要被400整除才是闰年,否则为平年(2000闰年,1700平年);如果是非整百年(如2008,2009),只要被4整除就是闰年,不能被4整除为平年(2008闰年,2009平年)。

所以判断是否为闰年的写法就很固定:

static boolean isLeap(int y){ return (y % 4 == 0 && y % 100 != 0) || (y % 400 == 0); }

也就是闰年是能被4整除且不能被100整除或者能被400整除的数字,平年的2月份只有28天而闰年2月份有29天。

计算某年有某月有几天

boolean isLeap(int year){ return (year % 400 == 0) || (year % 4 == 0 && year % 100 != 0); } int daysInMonth(int y, int m){ int[] d = {0,31,28,31,30,31,30,31,31,30,31,30,31}; if(m == 2 && isLeap(y)) return 29; return d[m]; }

给你一个年月返回有多少天,d代表每个月有多少天,如果是闰年2月份返回29天

日期自增

boolean isLeap(int year){ return (year % 400 == 0) || (year % 4 == 0 && year % 100 != 0); } int daysInMonth(int y, int m){ int[] d = {0,31,28,31,30,31,30,31,31,30,31,30,31}; if(m == 2 && isLeap(y)) return 29; return d[m]; } int[] nextDay(int y, int m, int d){ d++; if(d > daysInMonth(y,m)){ d = 1; m++; if(m > 12){ m = 1; y++; } } return new int[]{y,m,d}; }

1.先让日期自增,d++,比如 2016-11-18 → d=19 2.如果日期超过该月天数,d=1换月,月自增,如果月超过12,年自增,最后返回年月日,

枚举日期区间

while(!(y1==y2 && m1==m2 && d1==d2)){ // 在这里写你的逻辑,例如判断是否回文 int[] next = nextDay(y1, m1, d1); y1 = next[0]; m1 = next[1]; d1 = next[2]; } // 最后一天也要处理

只要不是结束日期,就继续加一天。

你能枚举区间中的每一天,例如:判断是否回文,判断日期是否合法,累计天数,统计某种日期天数,例如周六周末。

例:给出一个日期区间,判断区间内有多少回文日期

记住:回文日期不需要枚举每天,回文日期由年份决定。

注意:要判断日期是否合法(月份要满足1<=m<=12,天数要满足在当月天数内)

import java.util.*; public class Main{ static boolean isLeap(int y){ return (y%400==0 || (y%4==0 && y%100!=0)); } static int daysInMonth(int y,int m){ int[] d = {0,31,28,31,30,31,30,31,31,30,31,30,31}; if(m==2 && isLeap(y)) return 29; return d[m]; } // 把 YYYYMMDD 转成整数便于比较 static int makeDate(int y){ int m = y % 100; int d = y / 100; return y * 10000 + m * 100 + d; } public static void main(String[] args){ Scanner sc = new Scanner(System.in); int L = sc.nextInt(); int R = sc.nextInt(); int lYear = L / 10000; int rYear = R / 10000; int ans = 0; for(int y = lYear; y <= rYear; y++){ int m = y % 100; int d = y / 100; // 月份非法 if(m < 1 || m > 12) continue; // 日期非法 if(d < 1 || d > daysInMonth(y, m)) continue; int date = makeDate(y); // 判断是否在区间内 if(date >= L && date <= R) ans++; } System.out.println(ans); } }

模版需要背

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:04:33

Wan2.2-T2V-A14B能否生成符合人类视觉习惯的景深效果

Wan2.2-T2V-A14B能否生成符合人类视觉习惯的景深效果 在影视制作、广告创意乃至短视频内容爆发的今天&#xff0c;观众对视频“真实感”的要求早已超越了画面清晰和动作连贯。一个镜头是否具备自然的空间层次——比如前景人物清晰锐利&#xff0c;背景城市灯光柔和弥散成光斑—…

作者头像 李华
网站建设 2026/4/27 18:28:01

金融机构如何落地智能体?16个头部企业Agent最佳实践

文章介绍了金融业智能体(AI Agent)的定义、特征及应用进展。智能体具有自主性和学习能力&#xff0c;正被银行、证券、保险等金融机构广泛采纳。文章分析了智能体在金融领域的应用场景及面临的挑战&#xff0c;并提供了多个金融机构的智能体应用案例&#xff0c;为金融业智能体…

作者头像 李华
网站建设 2026/4/30 1:54:38

基于大数据的校园美食推荐系统的设计与实现scrapy+hadoop

文章目录项目简介系统截图大数据系统开发流程主要运用技术介绍参考文献结论源码文档获取定制开发/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;项目简介 本系统基于校园餐饮场景需求&#xff0c;采用模块化设计理念构建了完整的用户端和管理端功能…

作者头像 李华
网站建设 2026/4/30 10:11:44

探索双馈风力发电系统的双PWM变换器控制

双馈风力发电系统&#xff0c;双pwm变换器控制系统&#xff0c;采用直接转矩输入代替风力发电机。 &#xff08;1&#xff09;转子侧采用基于定子磁链定向的矢量控制策略&#xff0c;对d轴进行定向&#xff0c;采用双闭环控制结构&#xff0c;外环为速度环&#xff0c;内环为电…

作者头像 李华
网站建设 2026/5/1 4:23:05

AI 在智能交通系统的革命浪潮,应用架构师的应对之策

AI 在智能交通系统的革命浪潮:应用架构师的应对之策 引言:智能交通的「旧困境」与「新希望」 早高峰的北京三环,你握着方向盘看着前方望不到头的车龙,收音机里传来交通台的播报:「西直门桥双向拥堵,预计通行时间45分钟」;晚高峰的上海内环,一辆外卖电动车突然变道,引…

作者头像 李华