基姆拉尔森计算公式
算法如下:
基姆拉尔森计算公式
W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400+1) mod 7
在公式中d表示日期中的日数,m表示月份数,y表示年数。
注意:在公式中有个与其他公式不同的地方:
把一月和二月看成是上一年的十三月和十四月,例:如果是2004-1-10则换算成:2003-13-10来代入公式计算。
代码如下:
// java code
//y-年,m-月,d-日期
string CaculateWeekDay(int y,int m, int d)
{
if(m==1||m==2) {
m+=12;
y--;
}
int week=(d+2*m+3*(m+1)/5+y+y/4-y/100+y/400+1)%7;
string weekstr="";
switch(week)
{
case 1: weekstr="星期一"; break;
case 2: weekstr="星期二"; break;
case 3: weekstr="星期三"; break;
case 4: weekstr="星期四"; break;
case 5: weekstr="星期五"; break;
case 6: weekstr="星期六"; break;
case 0: weekstr="星期日"; break;
}
return weekstr;
}
// C语言代码如下:测试的日期为2013年1月1号,结果为星期二;
#include <stdio.h>
void main()
{
int y=2013,m=1,d=1;
int w;
char *weekday[7]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Firday","Saturday"};
if (m==1 || m==2)
m=m==1?13:14;
w=(d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7;
printf("%s\n",weekday[w]);
}
void main()
{
int y=2013,m=1,d=1;
int w;
char *weekday[7]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Firday","Saturday"};
if (m==1 || m==2)
m=m==1?13:14;
w=(d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7;
printf("%s\n",weekday[w]);
}
fun1(y,m,d)
{
int k;
if(m==1||m==2){m+=12;y--;}
return (int)((d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)+1)%7;
}
调试了2007,很正确的输出了
改进
int fun_change(int year, int month, int day)
{
if(month == 1 | month == 2)
{
month += 12;
--year;
}
int week = -1;
week = (day + 2 * month + 3 * (month + 1) / 5 + year + year / 4 -year / 100 +year / 400) % 7 + 1;
return week; // 输出-1为错误
}
输出1-7 分别代表 周一到周日,少了上述的switch语句。(已测试)