CCF节日

在这里插入图片描述

思路

强行模拟,计算1849年的12月31日开始,至year年的a月是第多少天(因为1949年的12月31日是周一,所以不从1850年的1月1日开始算,a的含义见题意)。

#include <bits/stdc++.h>
using namespace std;
int a, b, c, x, y, days[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
int leap(int n) {
    return n % 400 == 0 || (n % 4 == 0 && n % 100 != 0);
}
int first(int year, int month) {
    int ans = 1;
    for(int i = 1850; i < year; i++) ans += leap(i) + 365;
    for(int i = 1; i < month; i++) ans += days[i] + (i == 2 && leap(year));
    return ans;
}
int main() {
    scanf("%d %d %d %d %d", &a, &b, &c, &x, &y);
    for(int i = x; i <= y; i++) {
        int s = first(i, a) + 1, day = 1;
        while((s - 1) % 7 + 1 != c) day++, s++;
        day = (b - 1) * 7 + day;
        if(day > days[a] + (a == 2) * leap(i)) printf("none\n");
        else printf("%04d/%02d/%02d\n", i, a, day);
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值