找到万年历的算法了, 很酷的一个 :)
//算法如下:基姆拉尔森计算公式
//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来代入公式计算。
#include <stdio.h>
int main( void )
{
//W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7
int w, d, m, y;
char day[][10]={"一", "二", "三", "四", "五", "六","日"};
while(scanf("%d%d%d", &y, &m, &d)!=EOF){
if(m<=2) y--, m+=12;
w = (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) % 7;
printf("星期%s\n", day[w]);
}
} |