萬年曆製作,要注意的是時間天數的計算,以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;
}
五、演示結果