解
蓝桥杯接触过一点应该就很简单。这里的代码没有局限于一年的,所以比较长。
重点就是闰年的判断以及在每一月的最后一天边界值的判断。
//
// Created by 29273 on 2021-04-05.
//
#include "bits/stdc++.h"
using namespace std;
int isLeepYear(int y) {
return (y % 400 == 0) || ((y % 100) && (y % 4 == 0));
}
int main() {
int y, d;
cin >> y >> d;
int M = 1;
int D = 0;
while (d--) {
if (D == 32 && M == 12) {
M = 1;
D = 1;
}
if (D == 32 && (M == 1 || M == 3 || M == 5 || M == 7 || M == 8 || M == 10)) {
M++;
D = 1;
}
if (D == 31 && (M == 4 || M == 6 || M == 9 || M == 11)) {
M++;
D = 1;
}
if (isLeepYear(y) && D == 30 && M == 2) {
M = 3;
D = 1;
}
if (!isLeepYear(y) && D == 29 && M == 2) {
M = 3;
D = 1;
}
D++;
}
printf("%d\n%d\n", M, D);
return 0;
}