Csp认证-201509-2-日期计算

蓝桥杯接触过一点应该就很简单。这里的代码没有局限于一年的,所以比较长。

重点就是闰年的判断以及在每一月的最后一天边界值的判断。

复制代码
//
// Created by 29273 on 2021-04-05.
//
#include "bits/stdc++.h"

using namespace std;

int isLeepYear(int y) {
    return (y % 400 == 0) || ((y % 100) && (y % 4 == 0));
}

int main() {
    int y, d;
    cin >> y >> d;
    int M = 1;
    int D = 0;
    while (d--) {
        if (D == 32 && M == 12) {
            M = 1;
            D = 1;
        }
        if (D == 32 && (M == 1 || M == 3 || M == 5 || M == 7 || M == 8 || M == 10)) {
            M++;
            D = 1;
        }
        if (D == 31 && (M == 4 || M == 6 || M == 9 || M == 11)) {
            M++;
            D = 1;
        }
        if (isLeepYear(y) && D == 30 && M == 2) {
            M = 3;
            D = 1;
        }
        if (!isLeepYear(y) && D == 29 && M == 2) {
            M = 3;
            D = 1;
        }
        D++;
    }
    printf("%d\n%d\n", M, D);
    return 0;
}
posted @   沃特艾文儿  阅读(12)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示