设n年y月r日是星期x:
当y>=3时, n' = n,否则n' = n-1;
当y>=3时, y' = y-2,否则y' = y+10;
则:x = (n' + [n'/4] -[n'/100] + [n'/400] + [2.59*y'] + r) mod 7 ;
其中[t]表示t的整数部分。
C代码如下:
int solve(int n,int y,int r) //年、月、日
{
int nn ,yy;
if(y>=3)
nn = n;
else
nn = n-1;
if(y>=3)
yy = y-2;
else
yy = y+10;
return (nn + nn/4 - nn/100 + nn/400 + int(2.59*yy) + r)%7; //周日用0表示
}