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");
    }
 
 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值