[原]输入日期计算星期

#include "stdio.h" 

int get_week(int y,int m,int d)
{
   
int a=7/* 用来保存计算得到的星期几的整数*/
   
if((m==1)||(m==2))/*如果是一月或二月进行换算*/
   {
    m
+=12;
    y
--;
   }
   a
=(d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7;   /*基姆拉尔森计算公式,得到的星期几的整数*/
   
return a;

}

void PrintWeek(int weekday)
{
 
switch(weekday)
 {
  
case 6 : printf("%4s","Sun"); break;
  
case 0 : printf("%4s","Mon"); break;
  
case 1 : printf("%4s","Tue"); break;
  
case 2 : printf("%4s","Wed"); break;
  
case 3 : printf("%4s","Thu"); break;
  
case 4 : printf("%4s","Fri"); break;
  
case 5 : printf("%4s","Sat"); break;
 }
}
main()
{
 
int year,month,day;
 printf(
"Input the date:(yyyy-mm-dd)");
 scanf(
"%d-%d-%d",&year,&month,&day);
 
if((year<1)||(month<1||month>12)||(day<1||day>31))
 {
   printf(
"Invalid date format.\n");
   
/*break;*/
 }
 
/* 这里的验证不完善,如果输入的日期格式非法,不能中止程序,我也不记得怎么写了,你自己想一下. */
 printf(
"The week is");
 PrintWeek(get_week(year,month,day));
 printf(
"\n");
 getch();
}


/*
一:常用公式

W = [Y-1] + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D

Y是年份数,D是这一天在这一年中的累积天数,也就是这一天在这一年中是第几天。

二:蔡勒(Zeller)公式

w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1

公式中的符号含义如下,w:星期;c:世纪;y:年(两位数); m:月(m大于等于3,小
于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,比如2003年1
月1日要看作2002年的13月1日来计算);d:日;[ ]代表取整,即只要整数部分。

相比于通用通用计算公式而言,蔡勒(Zeller)公式大大降低了计算的复杂度。

三:对蔡勒(Zeller)公式的改进

作者:冯思琮
相比于另外一个通用通用计算公式而言,蔡勒(Zeller)公式大大降低了计算的复杂度。
不过,笔者给出的通用计算公式似乎更加简洁(包括运算过程)。现将公式列于其下:
W=[y/4]+r (y/7)-2r(c/4)+m’+d

公式中的符号含义如下,r ( )代表取余,即只要余数部分;m’是m的修正数,现给出1至
12月的修正数1’至12’如下:(1’,10’)=6;(2’,3’,11’)=2;(4’,7’)
=5;5’=0;6’=3;8’=1;(9’,12’)=4(注意:在公式中,y为润年时
1’=5;2’=1)。其他符号与蔡勒(Zeller)公式中的含义相同。

四:基姆拉尔森计算公式

W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7

在公式中d表示日期中的日数,m表示月份数,y表示年数。

注意:在公式中有个与其他公式不同的地方:

把一月和二月看成是上一年的十三月和十四月,例:如果是2004-1-10则换算成:2003-13-
10来代入公式计算?
*/


弟弟,程序里面的验证我没有写好,你自己想一下. 上面赋有算法说明,你认真看一下.
程序用了两个用户自定义函数,get_week返回一个int型的数,PrintWeek不返回值.
以后有什么问题,多交流

posted @ 2007-03-24 14:14  Kenny田  阅读(1077)  评论(1编辑  收藏  举报