蔡勒(Zeller)公式
随便给一个日期,就能用这个公式推算出是星期几。
蔡勒公式如下:
W = [C/4] - 2C + y + [y/4] + [13 * (M+1) / 5] + d - 1
或者是:
w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1
公式中的符号含义如下:
w:星期; w对7取模得:0-星期日,1-星期一,2-星期二,3-星期三,4-星期四,5-星期五,6-星期六
c:世纪-1(前两位数)
y:年(后两位数)
m:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,比如2003年1月1日要看作2002年的13月1日来计算)
d:日 [ ]代表取整,即只要整数部分。
下面以*成立100周年纪念日那天(2049年10月1日)来计算是星期几,过程如下:
w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1
=49+[49/4]+[20/4]-2×20+[26×(10+1)/10]+1-1
=49+[12.25]+5-40+[28.6]
=49+12+5-40+28
=54 (除以7余5)
即2049年10月1日(100周年国庆)是星期五。
再比如计算2013年3月7日,过程如下:
w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1
=13+[13/4]+[20/4]-220+[26(3+1)/10]+7-1
=-3 (除以7余4,注意对负数的取模运算!)
示例代码:
int return_week_day(unsigned int year, unsigned int month, unsigned int day)
{
int week = 0;
unsigned int y = 0, c = 0, m = 0, d = 0;
if(month == 1 || month == 2)
{
c = (year - 1) / 100;
y = (year - 1) % 100;
m = month + 12;
d = day;
}
else
{
c = year / 100;
y = year % 100;
m = month;
d = day;
}
week= y + y / 4 + c / 4 - 2 * c + 26 * ( m + 1 ) / 10 + d - 1; //蔡勒公式
week= week >= 0 ? ( week% 7 ) : ( week% 7 + 7 ); //week为负时取模
if ( week== 0 ) //星期日不作为一周的第一天
{
week= 7;
}
return week;
}
基姆拉尔森计算公式
int return_week_day(unsigned int year, unsigned int month, unsigned int day)
{
int week = 0;
if( month == 1 || month == 2) {
month += 12;
year--;
}
//使用基姆拉尔森计算公式
int week = ( d + 2 * m + 3 * ( m + 1 ) / 5 + y + y / 4 - y / 100 + y / 400 ) % 7;
return week + 1;
}