ACM之-求某天是星期几

/* 算法如下:   
基姆拉尔森计算公式
W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7  


在公式中d表示日期中的日数+1,m表示月份数,y表示年数。
  
注意1:在公式中有个与其他公式不同的地方:   
把一月和二月看成是上一年的十三月和十四月,
例:如果是2004-1-10则换算成:2003-13-10来代入公式计算。

注意2:在大多数天主教国家的日历中,在1752年没有9.3-9.13,在这一年的日历中9月2号
后面直接就是9月14号,所以在计算某天是星期几的算法中要把这一特殊情况考虑在内。

如果在在1752年9月3日之前
week = (d+2*m+3*(m+1)/5+y+y/4+5)%7;
如果不是
week = (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7;

*/

#include<iostream> #include<string> using namespace std; int CaculateWeekDay(int y,int m,int d){ int a; // 1月2月当作前一年的13,14月 if(m==1||m==2){ m += 12; y--; } //判断是否在1752年9月3号之前 if(y<1752||(y==1752&&m<9)||(y==1752&&m==9&&d<3)){ a = (d+2*m+3*(m+1)/5+y+y/4+5)%7; } else { a = (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7; } return a; } const char *name[]={"monday","tuesday","wednesday","thursday" ,"friday","saturday","sunday"}; int main(){ int y,m,d; while( cin >> y >> m >> d){ cout << name[CaculateWeekDay(y,m,d)] << endl; } system("pause"); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值