poj 3393 Lucky and Good Months by Gregorian Calendar 模拟

来源:互联网 发布:圆点是什么软件 编辑:程序博客网 时间:2024/05/16 11:11

详细分析见 http://www.cnblogs.com/lyy289065406/archive/2011/07/31/2122851.html


#include <stdio.h>#include <iostream>using namespace std;int flagRun=0;int sum;int Month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};   //平年月int Lmonth[13]={0,31,29,31,30,31,30,31,31,30,31,30,31};  //闰年月enum week{Sun,Mon,Tue,Wed,Thu,Fri,Sat};  //星期int leap(int year){     if(year<1582){         if(year%4==0)             return 1;         else return 0;     }else if(((year%4==0)&&(year%100!=0))||(year%400==0)||(year==1700))              return 1;           else              return 0;} int computeDay(int year,int month){  int day=1;  int i;  for(i=1;i<year;i++){     if(leap(i))        day+=366;     else         day+=365;      }    for(int j=1;j<month;j++)         if(leap(i))            day+=Lmonth[j];         else            day+=Month[j];      if(year>1752)        day-=11;     else if(year==1752 && month>9)         day-=11;      return day;}int main(){    int test;    cin>>test;    while(test--){       int ys,ms,ye,me;       int *pm;        int i,j;        cin>>ys>>ms>>ye>>me;        int luck=0,good=0;        int day= computeDay(ys,ms);         if(((day+5)%7<=Mon) || ((day+5)%7==Sat))  //计算起始ys年ms月1号为星期几,判断是否为good month              good++;                               //1年1月1号是星期六,而原本默认是星期日,因此+5调整         for(i=ys;i<ye;i++){                             if(leap(i))                pm=Lmonth;             else                 pm=Month;             if(i==ys)                j=ms;              else                 j=1;             for(;j<13;j++){                 day+=*(pm+j);                 if(i==1752&&j==9)                    day-=11;                                      if(((day+5)%7<=Mon)||((day+5)%7==Sat)){                      good++;                      luck++;//当j+1月good month,第j月必为luck month                                                         }                                              }                                 }                     /* 计算第ye年的good,luck month */         if(leap(i))           pm=Lmonth;         else           pm=Month;         if(i==ys)//即ys=ye            j=ms;          else j=1;          for(;j<=me;j++){              day+=*(pm+j);              if(i==1752&&j==9)                 day-=11;                               if(((day+5)%7<=Mon)||((day+5)%7==Sat)){                   if(j!=me)                         good++;                      luck++;//当j+1月good month,第j月必为luck month                                                     }                                     }         cout<<luck<<' '<<good<<endl;    }     system("PAUSE");    return 0;}


原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 阴茎勃起的时间不长怎么办 睡觉的时间不长怎么办 每次锻炼时间不长怎么办 微信好友不知道是谁怎么办 就一个软件闪退怎么办 葫芦侠修改闪退怎么办 戴尔游匣磁盘占用100怎么办 步步高家教机扫描笔不亮怎么办 社保卡手机号换了怎么办 香港公司进出口没有申报怎么办 智能电视右上角网络未连接怎么办 电子秤按键板不好用怎么办失灵 桑塔纳车钥匙锁车里了怎么办 舌头上有锯齿印怎么办 夏天有脚气脚臭怎么办 xp分辨率太高黑屏怎么办 农村淘宝标识类目没了怎么办 被投诉到食品监督局怎么办 被客户315投诉了怎么办 给人打不接受调解怎么办 失业证年审忘了怎么办 工商年检过期4天怎么办 个体营业执照年审过期了怎么办 企业年报密码忘了怎么办 税务年报报错了怎么办 工商证过期5年怎么办 车年检标志丢了怎么办 年检标志打错了怎么办 贵州个体出租车工商执照年检怎么办 驾驶证考试预约提示网络繁忙怎么办 帝豪显示屏花屏怎么办 注册公司居委会不盖章怎么办 营业执照名字和店名不一样怎么办 开炸鸡店没经验怎么办 提名候选人时重名重姓怎么办 别人用我的店名怎么办 wish店铺出现侵权产品怎么办 如果公司缺人该怎么办 鲁班奖证书丢了怎么办 个人注册服务号没有营业执照怎么办 社保过了缴费日怎么办