[蓝桥杯 2017 省 B] 日期问题

小明正在整理一批历史文献。这些历史文献中出现了很多日期。小明知道这些日期都在 1960 年 1 月 1 日至 2059 年 12 月 31 日。令小明头疼的是,这些日期采用的格式非常不统一,有采用年/月/日的,有采用月/日/年的,还有采用日/月/年的。更加麻烦的是,年份也都省略了前两位,使得文献上的一个日期,存在很多可能的日期与其对应。

比如 02/03/04,可能是 2002 年 03 月 04 日、2004 年 02 月 03 日或 2004 年 03 月 02 日。

给出一个文献上的日期,你能帮助小明判断有哪些可能的日期对其对应吗?

输入 #

复制代码
02/03/04

输出 #

复制代码
2002-03-04  
2004-02-03  
2004-03-02 

#include <iostream>

using namespace std;

int days[13]={0,31,30,31,30,31,30,31,31,30,31,30,31};

bool check_valid(int year,int month,int day){ //重点

if(month==0 ||month>12){ //判断

return false;

if(day==0 ||month!=2 &&day>days[month])

return false;

if(month==2){ //如果是二月特殊情况

int leap=year%100!=0 &&year%4==0 ||year%400==0;

if(day>days[2]+leap)

return false;

}

}

return true;

}

int main(int argc, char** argv) {

int a,b,c;

scanf("%a/%b/%c",&a,&b,&c);

for(int i=19600101;i<=20251231;i++){

int year=i/1000, month=i/100%100, day=i%100; //分别取年月日

if(check_valid(year,month,day)){ //自定义方法,检查是否满足条件。

if(year%100==a && month==b &&day==c ||month==a &&day==b &&year%100==c ||day==a &&month==b &&year%100==c){ //重点

printf("%d-%02d-%02d\n",year,month,day);

}

}

}

return 0;

}

相关推荐
ZZZS05165 分钟前
stack栈练习
c++·笔记·学习·算法·动态规划
hans汉斯31 分钟前
【人工智能与机器人研究】基于力传感器坐标系预标定的重力补偿算法
人工智能·算法·机器人·信号处理·深度神经网络
vortex52 小时前
算法设计与分析:分治、动态规划与贪心算法的异同与选择
算法·贪心算法·动态规划
前端拿破轮2 小时前
🤡🤡🤡面试官:就你这还每天刷leetcode?连四数相加和四数之和都分不清!
算法·leetcode·面试
地平线开发者3 小时前
征程 6|工具链量化简介与代码实操
算法·自动驾驶
DoraBigHead3 小时前
🧠 小哆啦解题记——谁偷改了狗狗的台词?
算法
Kaltistss3 小时前
240.搜索二维矩阵Ⅱ
线性代数·算法·矩阵
轻语呢喃3 小时前
每日LeetCode:合并两个有序数组
javascript·算法
unicrom_深圳市由你创科技3 小时前
Unity开发如何解决iOS闪退问题
unity·ios·蓝桥杯
大熊猫侯佩4 小时前
Swift 数学计算:用 Accelerate 框架让性能“加速吃鸡”
算法·swift