C++中星期几计算公式
2016-11-30 18:12
239 查看
蔡勒公式(Zeller):是一个计算星期的公式。
随便给一个日期,就可以使用这个公式推算出事星期几。
公式如下:Weeks = [C/4] - 2C + y + [y/4] + [13*(M +1)/5] + d -1;
或者是Weeks = y + [y/4] + [c/4] - 2c + [26(m + 1)/10] + d - 1;
公式中的符号含义如下:
Weeks:星期总数;用7取模得:1,2,3,4,5,6,0 对应星期一到星期日
C:世纪-1(前两位数)
Y:年(后两位数)
M:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、 2月要看做上一年的13、 14月来计算,比如2003年1月1日要看做2002年的13月1日来算)
D:Day代表取整
若要计算的日期是在1582年10月4日或之前,公式则为 Weeks=Y+[Y/4] + [C/4] -2C + [13(m+1)/5] + d + 2;
蔡勒公式只适合于1582年10月15日之后的情形。罗马教皇格里高利十三世在1582年组织了一批天文学家,根据哥白尼日心说计算出来的数据,对儒略历做了修改。将1582年10月5日到14日之间的10天宣布撤销,继10月4日之后为10月15日。后来人们将这一新的历法称为“格里高利历”,也就是今天世界上所通用的历法,简称格里历或公历。
比如说计算今天的星期几:
//蔡勒公式计算星期几;
int DayOfTheWeek(int nYear, int nMonth, int nDay)
{
//Y+[Y/4] + [C/4] - 2C + [26(M+1)/10] + d -1;Y 2016中的16,C代表20, m是month,day是日;
int nHelpYear = 0;
int nHelpMonth = 0;
if(nMonth==1 || nMonth ==2)
{
nHelpYear = nYear - 1;
nHelpMonth = 12 + nMonth;
}
else
{
nHelpYear = nYear;
nHelpMonth = nMonth;
}
int nY = nHelpYear/ 100;
int nC = nHelpYear% 100;
int nWeeks = nY + nY / 4 + nC / 4 - 2 * nC + 26 * (nHelpMonth + 1) / 10 + nDay - 1;
int nWeek = nWeeks % 7;
if (nWeek >= 0)
{
return nWeek;
}
else
{
return nWeek + 7;
}
}
随便给一个日期,就可以使用这个公式推算出事星期几。
公式如下:Weeks = [C/4] - 2C + y + [y/4] + [13*(M +1)/5] + d -1;
或者是Weeks = y + [y/4] + [c/4] - 2c + [26(m + 1)/10] + d - 1;
公式中的符号含义如下:
Weeks:星期总数;用7取模得:1,2,3,4,5,6,0 对应星期一到星期日
C:世纪-1(前两位数)
Y:年(后两位数)
M:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、 2月要看做上一年的13、 14月来计算,比如2003年1月1日要看做2002年的13月1日来算)
D:Day代表取整
若要计算的日期是在1582年10月4日或之前,公式则为 Weeks=Y+[Y/4] + [C/4] -2C + [13(m+1)/5] + d + 2;
蔡勒公式只适合于1582年10月15日之后的情形。罗马教皇格里高利十三世在1582年组织了一批天文学家,根据哥白尼日心说计算出来的数据,对儒略历做了修改。将1582年10月5日到14日之间的10天宣布撤销,继10月4日之后为10月15日。后来人们将这一新的历法称为“格里高利历”,也就是今天世界上所通用的历法,简称格里历或公历。
比如说计算今天的星期几:
//蔡勒公式计算星期几;
int DayOfTheWeek(int nYear, int nMonth, int nDay)
{
//Y+[Y/4] + [C/4] - 2C + [26(M+1)/10] + d -1;Y 2016中的16,C代表20, m是month,day是日;
int nHelpYear = 0;
int nHelpMonth = 0;
if(nMonth==1 || nMonth ==2)
{
nHelpYear = nYear - 1;
nHelpMonth = 12 + nMonth;
}
else
{
nHelpYear = nYear;
nHelpMonth = nMonth;
}
int nY = nHelpYear/ 100;
int nC = nHelpYear% 100;
int nWeeks = nY + nY / 4 + nC / 4 - 2 * nC + 26 * (nHelpMonth + 1) / 10 + nDay - 1;
int nWeek = nWeeks % 7;
if (nWeek >= 0)
{
return nWeek;
}
else
{
return nWeek + 7;
}
}
当然对于里面1900前的事情,貌似大家暂时也用不到,可以了解,有问题可以直接查。有点错误修正一下。
相关文章推荐
- 18位号码身份证校验码的计算公式(c++)
- 番茄零乱初学C#之计算某天是星期几[蔡勒(Zeller)公式]
- 计算某一日期是星期几的公式(蔡勒公式)
- C++中数组求偏移量计算公式
- C++中计算类的大小的公式
- 如何计算某一天是星期几?—— 蔡勒(Zeller)公式
- c++ 计算某个日期是星期几,判断某年某月一号是星期几
- 使用蔡勒(Zeller)公式计算任意一天星期几
- 快速计算某个日期是星期几的经验公式
- 【c++程序】任意给两个日期,计算相差多少天和各自星期几
- c++实现18位身份证校验码的计算公式(转载)
- 蔡勒(Zeller)公式:根据日期计算星期几
- 如何计算某一天是星期几?(Kim larsson公式)
- 蔡勒公式 计算星期几
- C++上机报告 利用公式计算π=4(1-1/3+1/5-1/7+1/9-...)的近似值,直到括号中最后一项的绝对值小于0.000001为止。
- 根据年月日,计算出是星期几的牛逼公式
- 如何计算某一天是星期几?(Zeller公式)
- 计算星期几的公式
- 计算星期几的公式
- C/C++ 使用蔡勒公式计算日期对应星期几