题目描述
打印出任意年份的日历。提示:要判断该年份是否是闰年,若是闰年,二月为29天,平年为28天。而判断闰年的规则是:如果((该年能被4除尽且不能被100除尽) 或 能被400除尽),则该年是闰年。
输入
输入年份。
输出
与输入相对应,输出该年12个月的日历。
样例输入
2012
样例输出
*Mon Tue Wed Thu Fri Sat Sun
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31
*Mon Tue Wed Thu Fri Sat Sun
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29
*Mon Tue Wed Thu Fri Sat Sun
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
*Mon Tue Wed Thu Fri Sat Sun
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30
*Mon Tue Wed Thu Fri Sat Sun
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31
*Mon Tue Wed Thu Fri Sat Sun
1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30
*Mon Tue Wed Thu Fri Sat Sun
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31
*Mon Tue Wed Thu Fri Sat Sun
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31
*Mon Tue Wed Thu Fri Sat Sun
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
*Mon Tue Wed Thu Fri Sat Sun
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
*Mon Tue Wed Thu Fri Sat Sun
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30
*Mon Tue Wed Thu Fri Sat Sun
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31
提示
重点是要将某天对应星期几算出来,其它就只要搞好排版就行了。
关于求星期几,可以先找一个基准,比如1年1月1日是星期一,或1990年1月1日是星期一,然后按7天一个周期,计算出任意一天是星期几。当然,这还需要知道每个月有多少天,2月份还要看是否是闰年。
代码如下:
#include<stdio.h>
#include<stdlib.h>
int main()
{
int p[12]= {31,28,31,30,31,30,31,31,30,31,30,31};
int a,day,year,i,j,l;
scanf("%d",&year);
for(i=2,a=1; i<=year; i++)
{
day=365;
if(((i-1)%4==0&&(i-1)%100!=0)||(i-1)%400==0)
day++;
a=(a+day%7)%7;
}
if(a==0)
a+=7;
day=365;
if((year%4==0&&year%100!=0)||year%400==0)
{
day++;
p[1]++;
}
for(i=0; i<=11; i++)
{
printf("*Mon Tue Wed Thu Fri Sat Sun\n");
for(j=0 ; j<a-1; j++)
printf(" ");
for(l=1; l<=p[i]; l++)
{
printf("%4d",l);
if((a-1+l)%7==0&&l!=p[i])
printf("\n");
}
a=(a+p[i]%7)%7;
if(a==0)
a+=7;
printf("\n");
}
return 0;
}