news 2026/2/19 16:44:34

日期题模版(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/2/14 23:50:49

CppCon 2024 学习:Gazing Beyond Reflection for C++26

1⃣ 第一个片段 源语言构造&#xff08;语法域&#xff09; ^^std::vector<int> ^^int(*)() ^^std::cout ^^std::vector ^^std ^^::理解 这里的 ^^ 是一个元语言标记&#xff0c;表示这是语法结构的占位符&#xff0c;即“元变量”。它们代表的是代码中的语法单元&…

作者头像 李华
网站建设 2026/2/18 23:22:11

c++--_

map

作者头像 李华
网站建设 2026/2/14 16:50:59

Day9 >> 151、反转字符串中的单词 +

代码随想录字符串部分 151、反转字符串中的单词 这道题感觉还挺难的&#xff0c;而且好多种解法啊&#xff0c;Java版本总共给了4种解法&#xff0c;先挑了其中一个较容易理解的解法练习了一遍。 练习的过程中&#xff0c;写删除多余空格方法时&#xff0c;把 while 判断条件…

作者头像 李华
网站建设 2026/2/17 22:08:14

三星三折叠价格和功能揭秘:19999元起,三折叠旗舰藏多少惊喜?

万元级折叠屏市场再添重磅选手&#xff0c;三星GalaxyZTriFold以19999元起售的定价登场&#xff0c;其功能配置是否能匹配高端定位&#xff1f;今天我们就聚焦“三星三折叠价格和功能”&#xff0c;拆解这款旗舰的价值内核。价格定位清晰&#xff1a;双版本覆盖高端需求关于消费…

作者头像 李华
网站建设 2026/2/11 13:25:30

探索近乎完全消光的圆二色超反射镜与圆偏振光设置

近乎完全消光的圆二色超反射镜 圆偏振光的设置在光学领域&#xff0c;圆二色超反射镜以及圆偏振光的相关研究一直是极具吸引力的方向。今天咱们就来聊聊近乎完全消光的圆二色超反射镜以及圆偏振光的设置那些事儿。 近乎完全消光的圆二色超反射镜 圆二色性&#xff08;CD&#…

作者头像 李华
网站建设 2026/2/19 12:00:57

Wan2.2-T2V-A14B用于城市交通流量模拟可视化展示

Wan2.2-T2V-A14B&#xff1a;让城市交通“动”起来的AI视觉引擎 你有没有想过&#xff0c;未来的交通指挥中心不再是一堆密密麻麻的折线图和数字报表&#xff0c;而是一块块高清大屏上实时“播放”的动态街景&#xff1f;车流如织、红绿灯切换、公交专用道畅通无阻——这一切不…

作者头像 李华