万年历c语言自上而下,C语言实现万年历

给出你想知道的年份,便可以计算出该年对应的每个月每个日所对应的星期数,是不是感觉很好玩 ?

#include

#include

long int f(int year,int month)

{

/*f(年,月)=年-1,如月<3;否则,f(年,月)=年*/

if(month<3) return year-1;

else return year;

}

long int g(int month)

{

/*g(月)=月+13,如月<3;否则,g(月)=月+1*/

if(month<3) return month+13;

else return month+1;

}

long int n(int year,int month,int day)

{

/*N=1461*f(年、月)/4+153*g(月)/5+日*/

return 1461L*f(year,month)/4+153L*g(month)/5+day;

}

int w(int year,int month,int day)

{

/*w=(N-621049)%7(0<=w<7)*/

return(int)((n(year,month,day)%7-621049L%7+7)%7);

}

int date[12][6][7];

int day_tbl[ ][12]= {{31,28,31,30,31,30,31,31,30,31,30,31},

{31,29,31,30,31,30,31,31,30,31,30,31}

};

int main()

{

int sw,leap,i,j,k,wd,day;

int year;/*年*/

char title[]="SUN MON TUE WED THU FRI SAT";

//clrscr();

printf("Please input the year whose calendar you want to know: ");/*输入年*/

scanf("%d%*c",&year);/*输入年份值和掠过值后的回车*/

sw=w(year,1,1);

leap=year%4==0&&year%100||year%400==0;/*判闰年*/

for(i=0; i<12; i++)

for(j=0; j<6; j++)

for(k=0; k<7; k++)

date[i][j][k]=0;/*日期表置0*/

for(i=0; i<12; i++) /*一年十二个月*/

for(wd=0,day=1; day<=day_tbl[leap][i]; day++)

{

/*将第i+1月的日期填入日期表*/

date[i][wd][sw]=day;

sw=++sw%7;/*每星期七天,以0至6计数*/

if(sw==0) wd++;/*日期表每七天一行,星期天开始新的一行*/

}

printf("\n|==================The Calendar of Year %d =====================|\n|",year);

for(i=0; i<6; i++)

{

/*先测算第i+1月和第i+7月的最大星期数*/

for(wd=0,k=0; k<7; k++) /*日期表的第六行有日期,则wd!=0*/

wd+=date[i][5][k]+date[i+6][5][k];

wd=wd?6:5;

printf("%2d %s %2d %s |\n|",i+1,title,i+7,title);

for(j=0; j

{

printf(" ");/*输出四个空白符*/

/*左栏为第i+1月,右栏为第i+7月*/

for(k=0; k<7; k++)

if(date[i][j][k])

printf("%4d",date[i][j][k]);

else printf(" ");

printf(" ");/*输出十个空白符*/

for(k=0; k<7; k++)

if(date[i+6][j][k])

printf("%4d",date[i+6][j][k]);

else printf(" ");

printf(" |\n|");

}

/*scanf("%*c");/*键入回车输出下一个月的日历*/

}

puts("=================================================================|");

puts("\n Press any key to quit...");

getch();

return 0;

}

下面是我测试过的2015年对应的程序运行结果;

7b84e44008c92ea9f0b64fc910ee99b0.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值