题目描述
在西方,每月的 13 日如果正好是星期五,一般称之为黑色星期五。给定一个整数 y,代表所在年份,再给定一个整数 w,代表该年度 1 月 1 日的星期数(周一至周六以 11 到 66 表示,周日以 77 表示)。请输出该年度中,哪些月份存在黑色星期五。
输入格式
两个整数:y 与 w。
输出格式
若干行:每行一个整数,表示当年黑色星期五的月份,按照从小到大的顺序输出,若当年不存在黑色星期五,输出 None
。
数据范围
- 1≤100001≤y≤10000;
- 1≤71≤w≤7
样例数据
输入:
2017 7
输出:
1
10
说明:
2017年1月1日为周日,当年的黑色星期五在1月与10月
详见代码:
#include <bits/stdc++.h>
using namespace std;
int main() {
int y, w;
int day;
cin >> y >> w;
bool flag=1;
day = 13;
for (int i = 1; i <= 12; i++) {
if ((day + w - 1) % 7 == 5){
cout << i << endl;
flag=0;
}
if (i == 4 || i == 6 || i == 9 || i == 11) {
day += 30;
} else if (i == 2) {
if ((y % 4 == 0 && y % 100 != 0) || y % 400 == 0) {
day += 29;
} else {
day += 28;
}
} else {
day += 31;
}
}
if (flag==1){
cout<<"None";
}
return 0;
}