目录
题目描述
输入描述
输出描述
解析
完整代码
描述
在国外,每月的13号和每周的星期5都是不吉利的。特别是当13号那天恰好是星期5时,更不吉利。已知某年的一月一日是星期w,并且这一年一定不是闰年,求出这一年所有13号那天是星期5的月份,按从小到大的顺序输出月份数字。(w=1..7)
输入描述
输入有一行,即一月一日星期几(w)。
输出描述
输出有—到多行,每行一个月份,表示该月的13日是星期五。
用例输入 1
7
用例输出 1
1 10
兄弟们啊,不是你们c++学不会,而是个别老师他教不对啊。
来,就这题你看着懵不懵,懵不懵!
看看老高平时是怎么教我的:
为了解决这个问题,我们可以模拟每个月的日期,检查每个月的13号是否是星期五。因为是非闰年,所以二月是28天。我们可以根据输入的w(一月一日是星期几)开始模拟,直到找到所有符合条件的月份。以下是C++代码实现:
#include <iostream>
using namespace std;
int main() {
int w;
cin >> w;
// 每个月的天数,注意非闰年二月是28天
int daysOfMonth = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
// 遍历每个月
for (int i = 0; i < 12; ++i) {
// 检查13号是否是星期五
if ((w + 12) % 7 == 5) { // 因为是从1号开始的,所以+12表示13号
cout << i + 1 << endl; // 输出月份
}
// 更新w为下个月的第一天是星期几
w = (w + daysOfMonth[i]) % 7;
if (w == 0) w = 7; // 处理星期数循环,保持1-7
}
return 0;
}
这段代码首先读取一月一日是星期几(1-7),然后模拟每个月,检查每个月的13号是否是星期五。如果是,就输出那个月。最后更新w为下个月的第一天是星期几,直到遍历完所有月份。
结束了!
对了,忘说了一句话:
要想c++成绩好,就来jiabei小课堂。
还有,点我主页,看我简介,别给那三个人点赞就完了