C++ 欧拉计划#19
警告!前面是破坏者 您将获得以下信息,但您可能更愿意这样做 自己研究 1900年1月1日是星期一。 三十天是九月, 四月、六月和十一月。 其余的都有三十一个, 仅二月一日, 哪一个有二十八个,无论晴雨。 闰年是29岁 闰年发生在任何可以被4整除的年份,但除非它可以被400整除,否则不会发生在一个世纪。在二十世纪(1901年1月1日至2000年12月31日),有多少个星期日是在一个月的第一天 起初,这似乎是一个简单的问题。然而,当我编写解决方案时,我遇到了一个奇怪的问题——事实上,答案应该是171,但无论我做什么,我都会得到173。我已经一遍又一遍地查看了我的代码,但是仍然找不到bugC++ 欧拉计划#19,c++,C++,警告!前面是破坏者 您将获得以下信息,但您可能更愿意这样做 自己研究 1900年1月1日是星期一。 三十天是九月, 四月、六月和十一月。 其余的都有三十一个, 仅二月一日, 哪一个有二十八个,无论晴雨。 闰年是29岁 闰年发生在任何可以被4整除的年份,但除非它可以被400整除,否则不会发生在一个世纪。在二十世纪(1901年1月1日至2000年12月31日),有多少个星期日是在一个月的第一天 起初,这似乎是一个简单的问题。然而,当我编写解决方案时,我遇到了一个奇怪的问题——事实上,答案应该是171
#include <iostream>
using namespace std;
int main () {
int count = 0, days_in_month, days_passed = 1;
for (int i = 1900; i <= 2000; i++) {
for (int j = 1; j <= 12; j++) {
if (j == 4 || j == 6 || j == 9 || j == 11) {
days_in_month = 30;
} else if (j == 2) {
if (i % 400 == 0 || (i % 4 == 0 && i % 100 != 0)) {
days_in_month = 29;
} else {
days_in_month = 28;
}
} else {
days_in_month = 31;
}
if (days_passed % 7 == 0) {
count++;
}
days_passed += days_in_month;
}
}
cout << count << endl;
cin.ignore();
return 0;
}
#包括
使用名称空间std;
int main(){
整数计数=0,月内天数,通过天数=1;
对于(int i=1900;i您从1900开始i=1900
。问题是“1901年1月1日”。您从1900开始i=1900
。问题是“1901年1月1日”.不要只看你的代码,用调试器一行一行地检查它。在某一点上,它的行为必须与你所期望的不同。我所做的是查看所有数据,看看工作日是否在循环结束时也匹配。它们匹配了。这是困扰我的问题。请再次阅读说明。尤其是循环的定义“二十世纪".啊,现在我又觉得自己很愚蠢了。谢谢你!不要只看你的代码,用调试器一行一行地检查它。在某个时候,它的行为一定会与你期望的不同。我所做的是收集所有的数据,看看工作日是否在循环结束时也匹配。它们匹配了。这就是困扰我的地方。请再次阅读描述。特别是这是“二十世纪”的定义。啊,现在我又觉得自己很愚蠢了。谢谢!