积分规则 网站地图 帮助中心    
嵌入式软件 单 片 机 DSP 存储器 传感控制 光电显示
嵌入式硬件 CPLD/FPGA SOPC AD/DA 接口电路 模拟设计
I C设计 通信产品 汽车电子 电源产品 消费电子 数控系统
工业控制 军工/航天 安防产品 医疗电子 计算机外设 测试测量
供应 I C
求购 公司库

  IC 求购 销售 公司 论文 DATASHEET 参考设计 论坛
当前位置: 电子技术 >> 单片机 >> 相关文章
  相关分类: 相关文章 | 应用论文 | 新产品 | 下载 |
新编万年历星期速算法C语言的实现
 
作者:未知   来源:本站原创    点击数:500   更新时间:2007-10-8
您可以添加到网摘 让更多人关注此文章:

    #include <stdio.h>

code unsigned char WeekTab[] = {//闰年月星期表
  (3 << 5) + 31,//1月
  (6 << 5) + 29,//2月
  (0 << 5) + 31,//3月
  (3 << 5) + 30,//4月
  (5 << 5) + 31,//5月
  (1 << 5) + 30,//6月
  (3 << 5) + 31,//7月
  (6 << 5) + 31,//8月
  (1 << 5) + 30,//9月
  (4 << 5) + 31,//10月
  (0 << 5) + 30,//11月
  (2 << 5) + 31 //12月
};

/*------------------------------------------------------------------------------
----------
                                2000年~2099年星期算法
--------------------------------------------------------------------------------
---------*/
unsigned char WeekDay20(unsigned char y, unsigned char m, unsigned char d)
{
unsigned char week, day;
  day = WeekTab[m - 1];//月表
  week = day >> 5;//月星期数
  day &= 0x1f;//月天数
  if ((m < 3) && (y & 0x03)){//平年
    if (m == 2) day--;//平年月天数
    week++;//平年月表+1
  }
  y = y + (y >> 2);//年+年/4
  week = (week +  y + d + 2) % 7;//(星期=年+年/4+月表+2日)%7
  return (week << 5) | day;//返回星期和月天数
}

/*------------------------------------------------------------------------------
----------
                                0000年~9999年星期算法
--------------------------------------------------------------------------------
---------*/
unsigned char WeekDay(unsigned char c, unsigned char y, unsigned char m,
unsigned char d)
{
unsigned char week, day;
  c &= 0x03;//百年%4
  c = c | (c << 2);//百年%4*5
  day = WeekTab[m - 1];//月表
  week = day >> 5;//月星期数
  day &= 0x1f;//月天数
  if ((m < 3) && !((c == 0) | (y & ((y & 0x03) == 0)))){//平年
    if (m == 2) day--;//平年月天数
    week++;//平年月表+1
  }
  y = y + (y >> 2);//年+年/4
  week = (week + c + y + d + 2) % 7;//(星期=百年%4*5+年+年/4+月表+日+2)%7
  return (week << 5) | day;//返回星期和月天数
}

unsigned char BcdToBin(unsigned char val)
{
  val = (val >> 4) * 10 + (val & 0x0f);//将BCD码转换为10进制数
  return val;//返回10进制数
}

void main(void)
{
unsigned char c, y, m, d;
unsigned char cx, yx, mx, dx;  
unsigned char WDay, Week, Day;
/*---------------------------------------------------------
     0001年1月1日 星期天
---------------------------------------------------------*/
  c    = 0x00;
  y    = 0x01;
  m    = 0x01;
  d    = 0x01;
  cx   = BcdToBin(c);//百年
  yx   = BcdToBin(y);//年
  mx   = BcdToBin(m);//月
  dx   = BcdToBin(d);//日
  WDay = WeekDay(cx, yx, mx, dx);//取星期和月天数
  Week = WDay >> 5;//得到星期
  Day  = WDay & 0x1f;//得到最大月天数
/*---------------------------------------------------------
     1918年1月21日 星期一
---------------------------------------------------------*/
  c    = 0x19;
  y    = 0x18;
  m    = 0x01;
  d    = 0x21;
  cx   = BcdToBin(c);//百年
  yx   = BcdToBin(y);//年
  mx   = BcdToBin(m);//月
  dx   = BcdToBin(d);//日
  WDay = WeekDay(cx, yx, mx, dx);//取星期和月天数
  Week = WDay >> 5;//得到星期
  Day  = WDay & 0x1f;//得到最大月天数
/*---------------------------------------------------------
     9999年12月31日 星期天
---------------------------------------------------------*/
  c    = 0x00;
  y    = 0x01;
  m    = 0x01;
  d    = 0x01;
  cx   = BcdToBin(c);//百年
  yx   = BcdToBin(y);//年
  mx   = BcdToBin(m);//月
  dx   = BcdToBin(d);//日
  WDay = WeekDay(cx, yx, mx, dx);//取星期和月天数
  Week = WDay >> 5;//得到星期
  Day  = WDay & 0x1f;//得到最大月天数
/*---------------------------------------------------------
     2004年6月18日 星期五
---------------------------------------------------------*/
  c    = 0x20;
  y    = 0x04;
  m    = 0x06;
  d    = 0x18;
  cx   = BcdToBin(c);//百年
  yx   = BcdToBin(y);//年
  mx   = BcdToBin(m);//月
  dx   = BcdToBin(d);//日
  WDay = WeekDay20(yx, mx, dx);//取星期和月天数
  Week = WDay >> 5;//得到星期
  Day  = WDay & 0x1f;//得到最大月天数
/*---------------------------------------------------------
     2018年3月8日 星期四
---------------------------------------------------------*/
  c    = 0x20;
  y    = 0x18;
  m    = 0x03;
  d    = 0x08;
  cx   = BcdToBin(c);//百年
  yx   = BcdToBin(y);//年
  mx   = BcdToBin(m);//月
  dx   = BcdToBin(d);//日
  WDay = WeekDay20(yx, mx, dx);//取星期和月天数
  Week = WDay >> 5;//得到星期
  Day  = WDay & 0x1f;//得到最大月天数
  while(1);


相关文章
· 基于H.264的运动估计算法的DSP实现[160]
· 基于32位DSP的cache的结构设计及采用的算法[86]
· 基于改进波兹编码的符号位快速处理算法[203]
· 网络拓扑发现算法的分析[282]
· 基于Nios II的I2C总线接口的实现[122]
热门评论排行
·VHDL设计中电路简化问题的
·江苏嵌入式Linux教育培训
·锐极LINUX驱动培训班定于
·基于实时操作系统μC/OS-
·ARM处理器应用开发4步骤

文章评论
    没有任何评论
*只显示最新10条评论。评论内容只代表网友观点,与本站立场无关。更多评论
发表评论
  * 请先[登陆]再进行评论,谢谢。
评分: 1分 2分 3分 4分 5分
内容: *
发帖须知:
一.所发文章必须遵守《互联网电子公告服务管理规定》;
二.严禁发布供求代理信息,公司介绍,产品信息等广告宣传信息;
三.严禁恶意重复发帖;
四.严禁对个人,实体,民族,国家等进行漫骂,污蔑,诽谤。
 
热点新闻 [更多]
 
各种冲值卡批发销售!独家特价!
特价销售GPS车载导航系统!
数字电视批发销售!你想不到的价格!
品牌相机批发销售!你想不到的价格!
品牌手机批发销售!你想不到的价格!
笔记本电脑批发销售!你想不到的价格!
那一年我做了鸭子2
那一年我做了鸭子1
等你十年(下)
等你十年(上)
 
热门下载 [更多]
 
[ ] 手把手学单片机20个例
[ ] 单片机做的智能台灯
[ ] 单片机入门书
[ ] linux系统移植开发文档
[ ] IC卡的读写程序
[ ] 8051单片机C语言彻底应用
[ 常用软件] 555定时器电路设计软件V1.2
[ 常用软件] 51定时器计算软件
[ ] ARM处理器应用开发4步骤
[ ] 实用电源电路集锦
 
论坛新帖 [更多]
 
新店开业,部分开发板&元器件特...
[原创]VB编程RS232串口...
红外摄像机控制故障分析与处理方...
红外防水摄像机在智能视频监控中...
步进电机不用驱动芯片能驱动吗?...
我要选一块双串口,带AD的单片...
[分享]运放和功放的区别是什么...
4×4矩阵式键盘的课程设计...
做过高速信号滤波的高手帮忙...
做视频信号放大器,各位有什么好...

 
赞助商 [更多]
 


ICP许可证号:[粤 05056597]
联系电话:010-82517432 82517615 传真: 010-82517615

版权所有 Copyright © 2006 嵌入式技术网