2481|0

4

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

[笔记]学习万年历 [复制链接]

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

代码如下(已验证):

  1. /*******************************************************************************
    * Function Name : Gregorian_IsLeapYear
    * Description : 计算给定的年是否是闰年
    * Input : int y 指定年
    * Output : None
    * Return : 0 不是闰年 1 是闰年
    *******************************************************************************/
    char Gregorian_IsLeapYear(int y)
    {
    //闰年的规则:逢四闰,逢百不闰,逢四百再闰。
    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[i];
    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 = 0;//公元一年一月一日是星期一,所以起始值为星期日
    int ly,ry;
    //闰年次数

    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%7;
    return w;
    }
复制代码


[ 本帖最后由 threeyears 于 2012-1-5 13:20 编辑 ]
此帖出自单片机论坛
点赞 关注
 

回复
举报
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/6 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表