万年历制作,要注意的是时间天数的计算,以1901年1月1日周二为参考。每年365天,闰年366天,截止到要查询的年月,可以计算出总天数,其中每七天为一周,可以类推出周几。具体编写步骤如下:
一、闰年的判断
闰年年份相比非闰年,主要差异在二月的天数,若该年为闰年,二月则有29天。闰年的判断为,若是整百年份是400的倍数则为闰年,非整百年份是4的倍数则为闰年。函数如下:
bool check(int n) {
if (n % 4 != 0)return false;
if (n % 100 == 0 && n % 400 != 0)return false;
return true;
}
二、天数计算
每当输入一个日期,则相对应一个年份,一个月份。闰年366天,非闰年365;一三五七八十腊为大月,每月31天,四六九十一为小月,每月三十天,二月特殊,闰年29天,非闰年28天。比如显示2000年11月的日历,就要计算出从参照日期开始,截止到2000年11月1日的总天数,代码如下:
for (i = 1901; i < n; i++) {
if (check(i))day += 366;
else day += 365;
}
int a[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
if (check(n)) a[1] = 29;
for (int j = 0; j < y - 1; j++) {
day = day + a[j];
}
三、周计算
得出截止到待显示月份的第一天的总天数后,依据每七天一周循环,计算出每月的第一天是周几,再根据本月的天数,一次输出本月的日历,代码如下:
day = day % 7;
int t = day;
printf("sunday\tday1\tday2\tday3\tday4\tday5\tday6\n");
while (t--) {
printf("\t");
}
for (int k = 1; k <= a[y - 1]; k++) {
printf("%d\t", k);
if ((day + k) % 7 == 0)
printf("\n");
}
四、完整代码如下所示:
bool check(int n) {
if (n % 4 != 0)return false;
if (n % 100 == 0 && n % 400 != 0)return false;
return true;
}
int main() {
while (1) {
int n, y, i, day = 2;
scanf("%d %d", &n, &y);
for (i = 1901; i < n; i++) {
if (check(i))day += 366;
else day += 365;
}
int a[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
if (check(n)) a[1] = 29;
for (int j = 0; j < y - 1; j++) {
day = day + a[j];
}
printf("%d\n", day);
day = day % 7;
int t = day;
printf("sunday\tday1\tday2\tday3\tday4\tday5\tday6\n");
while (t--) {
printf("\t");
}
for (int k = 1; k <= a[y - 1]; k++) {
printf("%d\t", k);
if ((day + k) % 7 == 0)
printf("\n");
}
printf("\n");
}
return 0;
}
五、演示结果