你知道你生日那天是星期几吗,你知道你爸爸生日那天是星期几吗?你可能会说:可以查万年历啊。然而,不查万年历你能计算出来吗? 编程序实现:输入任意一个日期的年、月、日的值,求出从公元1年1月1日到该日期前一年的年末总共有多少天,到该日期前一个月的月末总共有多少天,到这一天总共有多少天,并求出这一天是星期几(用英文表示)。假定从公元第一天开始,就实施格里高利历法,并且公元1年1月1日为星期一。格里高利历法的置闰规则是400年97闰,也可以概括为:四闰百不闰,四百闰。 提示:可以将每个月的天数存入一个数组中。
输入格式:
输入年、月、日的值,数据之间以空格分隔。
输出格式:
数据之间以换行符分隔。
输入样例:
2012 3 31
输出样例:
734502
734562
734593
Saturday
qaq:后悔不应该错啊!
#include<stdio.h>
int main ()
{
int a[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
int b[13]={0,31,29,31,30,31,30,31,31,30,31,30,31};
char c[7][10]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};
int nian,yue,ri,tian=0,i;
scanf("%d %d %d",&nian,&yue,&ri);
tian=((nian-1)/4-(nian-1)/100+(nian-1)/400)+(nian-1)*365;//马虎错的点
printf("%d\n",tian);
if((nian%4==0&&nian%100!=0)||(nian%400==0))
{
for(i=1;i<yue;i++)
{
tian=tian+b[i];
}
}
else
{
for(i=1;i<yue;i++)
{
tian=tian+a[i];
}
}
printf("%d\n",tian);
tian=tian+ri;
printf("%d\n",tian);
printf("%s\n",c[tian%7]);
}