水题(然而还是没做出来,wttmcl),就是简单模拟
(之前写的特判有问题,修改了一下)
#include<cstdio>
#include<stack>
#include<queue>
#include<cmath>
#include<climits>
#include<cstring>
#include<cstdlib>
#include<cctype>
#include<algorithm>
#include<iostream>
#include<string>
#include<vector>
#define TP 233333333
using namespace std;
typedef long long ll;
typedef pair<int, int> P;
const int maxn = 1005;
bool is_run(int x) {
return (!(x%4) && x%100) || !(x%400); // 判断闰年
}
int main(void) {
int year, month, day;
while(cin >> year >> month >> day) {
int sum = 0;
if (month == 2 && day == 29) { //日期为2月29时要判断明年是否是闰年,同时最后符合条件的年份必定是闰年
while( !(!(sum%7) && is_run(year)) || !sum)
sum += is_run(++year) ? 366 : 365;
}
else {
while(!sum || sum%7) {
if (month <= 2)
sum += is_run(year++) ? 366 : 365; //因为上面特判已经排除2月29号, 所以闰年时有两种情况
else //月份小于等于二月 比如2月25号, 再加一年的时候会加上今年多闰出来的的2月29号
sum += is_run(++year) ? 366 : 365; //月份大于二月, 比如3月25号, 再加一年的时候会加上明年多闰出来的2月29号
}
}
cout << year << endl;
}
return 0;
}