注册 登录
电子工程世界-论坛 返回首页 EEWORLD首页 频道 EE大学堂 下载中心 Datasheet 专题
threeyears的个人空间 https://home.eeworld.com.cn/space-uid-372623.html [收藏] [复制] [分享] [RSS]
日志

[笔记]学习万年历

已有 750 次阅读2012-1-5 12:33

最近在看万年历算法,看的主要内容是杨和荣笔记 - 中国农历二百年算法及年历。
参考资料整理了公历算法,在使用时一般都是已经公历年月日,因而公历算法的关键
在于如何求出星期。

代码如下(稍后验证):
/*******************************************************************************
* Function Name  : Gregorian_IsLeapYear
* Description    : 计算给定的年是否是闰年
* Input          : int y 指定年
* Output         : None
* Return         : 0 不是闰年  1 是闰年
*******************************************************************************/
char Gregorian_IsLeapYear(int year)
{
  //闰年的规则:逢四闰,逢百不闰,逢四百再闰。
  char isLeap = 0;
  if (0 == y%4) isLeap = 1;
  if (0 == y%100) isLeap = 0;
  if (0 == y%400) isLeap = 1;
  return isLeap;
}

/*******************************************************************************
* Function Name  : Gregorian_DaySum
* Description    : 计算从年初至指定日期共计多少天(包括指定日期这天),用于计算星
*                  期。
* Input          : int y 年
*                  int m 月
*                  int d 日
* Output         : None
* Return         : 返回所求天数
*******************************************************************************/
int Gregorian_DaySum(int y, int m, int d)
{
  int mday[13] = {0,31,28,31,30,31,30,31,31,30,31,30,31};
  int sum = 0;
  int i;
  if (Gregorian_IsLeapYear(y))
    mday[2] = 29;
  for (i=1;i<m;i++)
    sum += mday;
  sum += d;
  return sum;
}

/*******************************************************************************
* Function Name  : Gregorian_GetWeek
* Description    : 计算指定年月日是星期几
* Input          : int y 年
*                  int m 月
*                  int d 日
* Output         : None
* Return         : 0~6 对应星期日、星期一...星期六
*******************************************************************************/
int Gregorian_GetWeek(int y, int m, int d)
{
  int w = 1;//公元一年一月一日是星期一,所以起始值为星期日
  int ly,ry;
  y = (y-1)%400 + 1;//公历星期值每400年循环一次
  //闰年次数
  ly = (y-1)/4;
  ly = ly - (y-1)/100;
  ly = ly + (y-1)/400;
  //常年次数
  ry = y - 1 - ly;
  w = w + ry;//常年星期值加一,365%7=1
  w = w + 2*ly;//闰年星期值加二,366%7=2
  w = w + Gregorian_DaySum(y,m,d);
  w = (w-1)%7 + 1;
  return w;
}

评论 (0 个评论)

facelist doodle 涂鸦板

您需要登录后才可以评论 登录 | 注册

热门文章