蓝桥杯12. 日期问题

发布于:2025-04-20 ⋅ 阅读:(56) ⋅ 点赞:(0)

日期问题

原题目链接

题目描述

小明正在整理一批历史文献。这些历史文献中出现了很多日期。

小明知道这些日期都在 1960 年 1 月 1 日2059 年 12 月 31 日 之间。

令小明头疼的是,这些日期采用的格式非常不统一:

  • 有的采用 年/月/日
  • 有的采用 月/日/年
  • 有的采用 日/月/年

更加麻烦的是,年份省略了前两位,例如:

02/03/04

它可能表示以下三种日期:

  • 2002 年 03 月 04 日 (年/月/日)
  • 2004 年 02 月 03 日 (日/月/年)
  • 2004 年 03 月 02 日 (月/日/年)

输入描述

一个日期字符串,格式为 AA/BB/CC,其中 0 ≤ A, B, C ≤ 9,即每个字段均为两位数字。


输出描述

输出若干个不相同的有效日期(在 1960-01-012059-12-31 范围内),每个日期一行,格式为:

yyyy-MM-dd

多个日期按从早到晚的时间顺序输出。


输入样例

02/03/04

输出样例

2002-03-04
2004-02-03
2004-03-02

c++代码

#include<bits/stdc++.h>

using namespace std;

int arr[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
unordered_set<string> st;

void valid(string a, string b, string c) {
    string d = "19";
    d += a;
    int year = stoi(d), key = 0, month = stoi(b), day = stoi(c);
    if (year % 400 == 0 || (year % 100 != 0 && year % 4 == 0)) key = 1;
    arr[2] += key;
    if (year >= 1960 && year <= 2059 &&
        month >= 1 && month <= 12 &&
        day >= 1 && day <= arr[month] &&
        st.find(d + "-" + b + "-" + c) == st.end()
    ) st.insert(d + "-" + b + "-" + c);
    arr[2] -= key;
    d = "20", d += a, key = 0, year = stoi(d);
    if (year % 400 == 0 || (year % 100 != 0 && year % 4 == 0)) key = 1;
    arr[2] += key;
    if (year >= 1960 && year <= 2059 &&
        month >= 1 && month <= 12 &&
        day >= 1 && day <= arr[month] &&
        st.find(d + "-" + b + "-" + c) == st.end()
    ) st.insert(d + "-" + b + "-" + c);
    arr[2] -= key;
}

int main() {
    string str, a, b, c;
    cin >> str;
    a = str.substr(0, 2), b = str.substr(3, 2), c = str.substr(6, 2);
    valid(a, b, c), valid(c, a, b), valid(c, b, a);
    vector<string> ans;
    for (string s : st) ans.push_back(s);
    sort(ans.begin(), ans.end());
    for (string s : ans) cout << s << endl;
    return 0;
}//by wqs

算法解析

注意这题需要判断闰年,然后就是暴力模拟就行了。


网站公告

今日签到

点亮在社区的每一天
去签到