目录
一、原理介绍
这里首先要介绍蔡勒(Zeller)公式。
蔡勒(Zeller)公式,是一个计算星期的公式,随便给一个日期,就能用这个公式推算出是星期几。
- W 是星期数。
- c 是世纪数减一,也就是年份的前两位。
- y 是年份的后两位。
- m 是月份。m 的取值范围是 3 至 14,因为某年的 1、2 月要看作上一年的 13、14月,比如 2019 年的 1 月 1 日要看作 2018 年的 13 月 1 日来计算。
- d 是日数。
- [] 是取整运算。
- mod 是求余运算。
二、实现代码
下面给出代码:
#include <stdio.h>
int main()
{
int year, month, day, week;
printf("请输入年月日:");
scanf("%d%d%d", &year, &month, &day);
// 判断月份是否为1或2,如果是,则将其视为上一年的13月或14月
if (month == 1 || month == 2)
{
month += 12;
year--;
}
// 使用Zeller公式计算星期几
week = (day + 2 * month + 3 * (month + 1) / 5 + year + year / 4 - year / 100 + year / 400) % 7;
switch (week)
{
case 0:
printf("星期一\n");
break;
case 1:
printf("星期二\n");
break;
case 2:
printf("星期三\n");
break;
case 3:
printf("星期四\n");
break;
case 4:
printf("星期五\n");
break;
case 5:
printf("星期六\n");
break;
case 6:
printf("星期日\n");
break;
}
return 0;
}
三、结果分析
运行代码,以2023年6月28日为例进行计算,结果为星期三。
打开日历,这一天确实为星期三。