当前位置: 首页 > news >正文

[蓝桥杯刷题]---模拟法[2]日期问题

题目如下: 

 
题目的意思是:

给出一个日期(格式是yy mm dd,注意年份只有两位数),要找出所有可能的真实日期(合法的yyyy-mm-dd格式)。

需要考虑:

年份范围在1960到2059。

输入的yy、mm、dd可能互换,比如02 03 04可以是2002-03-04、2004-03-02、2003-02-04等等,三者顺序可以交换。

按日期从早到晚排序输出。

#include <stdio.h>
#include <stdlib.h>typedef struct {int year, month, day;
} Date;// 判断是否是闰年
int isLeap(int year) {return (year % 400 == 0) || (year % 4 == 0 && year % 100 != 0);
}// 判断日期是否合法
int isValidDate(int year, int month, int day) {if (year < 1960 || year > 2059) return 0;if (month < 1 || month > 12) return 0;int days_in_month[] = {31,28,31,30,31,30,31,31,30,31,30,31};if (isLeap(year)) days_in_month[1] = 29;if (day < 1 || day > days_in_month[month - 1]) return 0;return 1;
}// 比较函数用于排序
int cmp(const void *a, const void *b) {Date *d1 = (Date *)a;Date *d2 = (Date *)b;if (d1->year != d2->year) return d1->year - d2->year;if (d1->month != d2->month) return d1->month - d2->month;return d1->day - d2->day;
}// 检查一个日期是否已经出现过
int isSame(Date *a, Date *b) {return a->year == b->year && a->month == b->month && a->day == b->day;
}int main() {int a[3];scanf("%d%d%d", &a[0], &a[1], &a[2]);Date dates[6]; // 最多6种排列int count = 0;// 枚举所有排列for (int i = 0; i < 3; i++) {for (int j = 0; j < 3; j++) {if (j == i) continue;for (int k = 0; k < 3; k++) {if (k == i || k == j) continue;int y = a[i], m = a[j], d = a[k];int year = (y >= 0 && y <= 59) ? (2000 + y) : (1900 + y);if (isValidDate(year, m, d)) {Date newDate = {year, m, d};int exist = 0;for (int t = 0; t < count; t++) {if (isSame(&dates[t], &newDate)) {exist = 1;break;}}if (!exist) {dates[count++] = newDate;}}}}}// 排序qsort(dates, count, sizeof(Date), cmp);// 输出for (int i = 0; i < count; i++) {printf("%04d-%02d-%02d\n", dates[i].year, dates[i].month, dates[i].day);}return 0;
}

 程序解析

结构体Date

用来存储一个日期的年、月、日。

闰年判断

如果年份能被400整除,或者能被4整除但不能被100整除,就是闰年。

日期是否合法

年份必须在1960-2059之间。

月份必须在1-12之间。

天数必须不超过该月的最大天数(闰年2月是29天)。

排列所有可能情况

输入的3个数,可以组成3! = 6种不同的排列。

每一种排列都转成一个完整的yyyy-mm-dd格式,然后判断是否合法。

注意避免重复保存相同的日期。

排序输出

用qsort按照年-月-日顺序排序。

最后按标准格式输出,每个日期一行。

输入:

2 3 4 

可能的日期(按排列枚举):

2002-03-04 (合法)

2002-04-03 (合法)

2003-02-04 (合法)

2003-04-02 (合法)

2004-02-03 (合法)

2004-03-02 (合法)

排序后输出:

2002-03-04

2002-04-03

2003-02-04

2003-04-02

2004-02-03

2004-03-02 

运行截图:

相关文章:

  • 【Nginx】 使用least_conn负载均衡算法是否能将客户端的长连接分散到不同的服务器上demo
  • 行政区划代码
  • 需要掌握的前端安全概念以及实操
  • 第8讲:坐标轴与刻度优化指南(字体、角度、格式处理)
  • 【C到Java的深度跃迁:从指针到对象,从过程到生态】第四模块·Java特性专精 —— 第十六章 多线程:从pthread到JMM的升维
  • OpenResty技术深度解析:原理、应用与生态对比-优雅草卓伊凡
  • 深入理解同源策略与跨域资源共享(CORS)
  • word插入APA格式的参考文献
  • Deepseek 生成新玩法:从文本到可下载 Word 文档?思路与实践
  • JVM 自动内存管理
  • 弹性盒子布局
  • 预训练大模型与元训练大模型在医疗AI项目中的选型对比分析
  • DELL R740服务器闪黄灯不开机故障案例
  • CSdiy java 05
  • 除了Object.freeze(),JavaScript中还有哪些优化性能的对象限制方法?
  • 蓝牙BLE
  • 蓝桥杯 18. 机器人繁殖
  • whois为什么有时会返回两个不同的域名状态
  • 【权限模型】RBAC模型详解
  • Spring Security源码解析
  • 赛力斯拟赴港上市:去年扭亏为盈净利59亿元,三年内实现百万销量目标
  • 一季度全国城镇新增就业308万人
  • 油电同智,安全超充!从上海车展看中国汽车产业先发优势
  • 程璧“自由生长”,刘卓辉“被旋律牵着走”
  • 四川苍溪县教育局通报“工作人员辱骂举报学生”:停职检查
  • 伊朗南部港口火势蔓延,部分集装箱再次发生爆炸