日期算法

c代码:
#include <stdio.h>
int main()
{
int year,month,day;
while(scanf("%d%d%d",&year,&month,&day)!=EOF)
{
if(month==1||month==2)//判断month是否为1或2
  
{
year--;
month+=12;
}
int c=year/100;
int y=year-c*100;
int week=(c/4)-2*c+(y+y/4)+(13*(month+1)/5)+day-1;
while(week<0){ week+=7; }
week%=7;
switch(week)
{
case 1: printf("Monday\n"); break;
case 2: printf("Tuesday\n"); break;
case 3: printf("Wednesday\n"); break;
case 4: printf("Thursday\n");break;
case 5: printf("Friday\n"); break;
case 6: printf("Saturday\n");break;
case 0: printf("Sunday\n"); break;
}
}
return 0;
}
C++代码:
#include <iostream>
using namespace std;
int main(){
int year,month,day;
while(cin >> year >> month >> day){
if (month < 3) {
year -= 1;
month += 12;
}
char b[7][10] = {"sunday","monday","tuesday","wednesday","thursday","friday","saturday"};
int c = int(year / 100),y = year - 100 * c;
int w = int(c / 4) - 2*c +y +int(y/4) +(26 * (month + 1)/10) + day - 1;
w = (w % 7 + 7) % 7;
cout << b[w] << endl;
Pascal代码
program clgs;
var a,b,c,d,x,y:longint;
beginreadln(a,b,d);
if b<3 then begin b:=b+12; a:=a-1; end;
y:=a mod 100;
c:=a div 100;
x:=y+trunc(y/4)+trunc(c/4)-2*c+trunc(13*(b+1)/5+d-1);
while x<=7 do
x:=x+7;
writeln((x-1)mod 7+1);
readln; readln;
end.

编辑本段其他公式

对于计算星期数的公式还有如下的公式:
Week=(Day + 2*Month + 3*(Month+1)/5 + Year + Year/4 - Year/100 + Year/400) % 7
(其中的Year是4位数的,如2009。“%”号是等式除7取余数)
注意:
i. 该公式中要把1月和2月分别当成上一年的13月和14月处理。
例如:2008年1月4日要换成 2007年13月4日带入公式。
ii.该式对应的与蔡勒公式有点区别:“0”为星期1,……,“6”为星期日。
改进:
该式可能与蔡勒公式的计算都是较为复杂,但有改进的地方:对于世纪这个概念不被引用,直接就是计算年代数(4位数)的!既不用再把 世纪 和 年代数(后两位)分开。
⒉基姆拉尔森计算公式
W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7 在公式中d表示日期中的日数+1,m表示月份数,y表示年数。
注意:改公式同上一个公式需要把一月和二月看成是上一年的十三月和十四月,不相同的只是代入公式的
d是日期加1。所以计算结果就是实际的星期,不需要加1.,即是:“1”为星期1,……,“7”为星期日。
例:如果是2004-1-10则换算成:2003-13-10来代入公式计算。
例:2006-10-17计算时:d=18,m=10,y=2006。
Java代码如下
string CaculateWeekDay(int y,int m,int d)
{
if(m==1) m=13;
if(m==2) m=14;
int week=(d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7;
string weekstr;
switch(week)
{
case 0: weekstr="星期一"; break;
case 1: weekstr="星期二"; break;
case 2: weekstr="星期三"; break;
case 3: weekstr="星期四"; break;
case 4: weekstr="星期五"; break;
case 5: weekstr="星期六"; break;
case 6: weekstr="星期日"; break;
}
return weekstr;
}
⒊(年+年/4+年/400-年/100-年基数+月基数+日)/7=……余星期几注:式中分数均取整 年基数,平年1,闰年2, 月基数,1、平年:一月0,二月3,三月3,四月6,五月1,六月4, 七月0,八月3,九月5,十月0,十一月3,十二月5. 2、闰年:一月0,二月3,三月4,四月0,五月2,六月5, 七月0,八月3,九月6,十月1,十一月4,十二月6.如:1949年10月1日是星期几? (1949+1949/4+1949/400-1949/100-1+0+1)/7=(1949+487+4-19-1+0+1)/7=345……6即该日为星期六。
所谓月基数,就是前几个月日数总和的7余数,如1月基数,前面月数的日数总和的7余数为0,则该月的基数就是0,如4月(闰年)基数,前面三个月的日数总和为:(31+29+31)/7=91/7……0 为了简化运算,先取各月7 余数,再相加,再取7余数:(3+1+3)/7……0,即4月基数为0,为了加快计算速度,通常是将平年和闰年的月基数编成基数表,直接查算。月基数,1、平年:一月0,二月3,三月3,四月6,五月1,六月4, 七月-1,八月2,九月5,十月0,十一月3,十二月5. 2、闰年:一月0,二月3,三月4,四月0,五月2,六月5, 七月0,八月3,九月6,十月1,十一月4,十二月6.
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
门禁卡(门禁控制卡)是指用于进出门禁系统的一种电子卡片。NFC(Near Field Communication,近场通讯)是一种短距离高频无线通信技术。日期算法是指用于计算日期和时间的数学算法。软件大全是指涵盖了某一领域或主题下所有相关软件的总集合。解密是指从密文中还原出明文的过程。 门禁卡与NFC技术结合,可以实现门禁系统的无接触识别,提高出入门禁的安全性和便利性。门禁卡的核心是内置了特定算法的芯片,通过与门禁读卡器的通信,验证卡片信息,实现控制门禁系统的目的。NFC技术可以实现门禁卡与读卡器之间的近距离通信,使得刷卡操作更加方便和快捷。 日期算法是用于计算日期和时间的一种数学算法。在门禁系统中,日期算法被用于判断门禁卡的有效期限,即判断当前日期是否在卡片的有效期范围内。通过日期算法,门禁系统可以及时识别过期的卡片,并拒绝其进入。 软件大全是指包含了某一领域或主题下所有相关软件的总集合。在门禁系统中,软件大全可能包括门禁卡的编码软件、门禁系统管理软件、门禁数据分析软件等。这些软件提供了门禁系统的全面功能,包括卡片的编码、系统的管理和数据的分析。 解密是指从密文中还原出明文的过程。在门禁系统中,解密是指门禁卡与读卡器之间的通信过程。当门禁卡与读卡器进行通信时,通过特定的解密算法将密文还原为明文,从而实现门禁卡的有效认证和控制门禁系统的操作。 总之,门禁卡与NFC技术的结合、日期算法的应用、软件大全的集合和解密的过程都是为了提高门禁系统的安全性和便利性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值