蔡勒公式
简介:
蔡勒(Zeller)公式,是一个计算星期的公式,随便给一个日期,就能用这个公式推算出是星期几。
w = (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400+1)%7;
符号说明:
符号 | 解释 |
---|---|
w | 星期,0-星期日,1-星期一,2-星期二,3-星期三,4-星期四,5-星期五,6-星期六 |
c | 年份前两位 |
y | 年(年份后两位 |
m | 月(在公式中,某年的1、2月要看作上一年的13、14月来计算,比如2019年1月1日要看作2018年的13月1日来计算) |
d | 日 |
[ ] | 代表取整,即只要整数部分。 |
注意:1.以上公式只适合于1582年10月15日之后的情形(当时的罗马教皇将恺撒大帝制订的儒略历修改成格里历,即今天使用的公历)
2.由于编程中数据都使用的是int整数类型,所以 [ ]可以直接去掉,整除直接使用/就行。
判断闰年:
可以被4整除且不能被100整除 或者 可以被400整除
跑步锻炼
月初或者星期1跑2公里
其他时间跑1公里
从2000.1.1号到2020.10.1
求跑的公里数
#include <iostream>
using namespace std;
int day[15]={0,31,28,31,30,31,30,31,31,30,31,30,31};
void runnian(int y){
if((y%4==0&&y%100!=0)||y%400==0)
day[2]=29;
else//不能省去,不能保证上一年2月是28天
day[2]=28;
}
int main()
{
int ans=0;
// runnian(2200);
// cout<<day[2];
int y=2000,m=1,d=1,w=6;
while(!(y==2020&&m==10&&d==1)){//2020.10.1截至
//今天
if(w==1 || d==1)
ans++;
ans++;
//明天
d++;
w=(w+1)%7;
if(d>day[m])
{
d=1;
m++;
if(m>12)
{
y++;
m=1;
}
}
runnian(y);
}
cout<<ans+2;//2020.10.1后没算
return 0;
}