http://poj.org/problem?id=3393

题意 : 对于这篇长长的英语阅读,表示无语无语再无语,花了好长时间,终于读完了。题目中规定每周的周六日为假日,其他为工作日,若是一个月的第一个工作日是周一,就定义这个月为good,若是一个周的最后一个工作日是周五,就定义这个月为luck。给你一个起始年月,一个终止年月,让你求出在这中间有多少luck月有多少good月。当然了,若是一整片文章就写了这点东西那也就太废话了,所以题目中还给出了几点应该注意的:

1.在1582年以前,只要年份取余4为0就为闰年,在1582年以后,年份取余4为0且取余100不为0或者是取余400为0才是闰年。

2.由于历史原因,1752年9月3日到9月13日是不存在的,也就是说1752年9月是少了11天的,只有19天。

3.由于历史原因,1700年无条件为闰年。

4.该历法从1年1月1日开始,这天为周六。

5.该历法每周有7天,从周六开始为第一天。

思路 :好麻烦的一道模拟题。。。。若是前一个月是luck,则下一个月必定为good,所以两个计数器可以同步,但是因为有边界问题,若是给出的起始月份是good,则前一个月份是不能够加进来的,而若是给定的终止月份是luck,那下一个月也不能加进来。为了算时好算,直接把从1年1月1日到起始日期的天数加了1,这也是为了防止出边界。所以,先算了起始月份是否是good,剩下的从起始月份开始,算的都是月份加1是不是good,luck。也就是说虽然写的是第 i 个月怎么样,但实际上,我们算的都是 i+1是不是good luck。算1年1月1日时,总的天数初始化为了1,使得直接加到了起始年份月份的第一天了,所以你每加一个月的天数,就直接加到了下一个月的第一天了,所以判断的就是下一个月的。

#include <iostream>
using namespace std ;
int mon[13] = {0,31,28,31,30,31,30,31,31,30,31,30,31} ;
int leapmon[13] = {0,31,29,31,30,31,30,31,31,30,31,30,31} ;
bool leap(int n)
{
    if(n < 1582)
    {
        if(n % 4 == 0)
        return true ;
        return false ;
    }
    else
    {
        if((n%4 == 0&&n%100!=0)||(n%400 == 0)||n==1700)
        return true;
        return false ;
    }
}
int sum(int startyear,int startmonth)
{
    int day = 1 ;
    for(int i = 1 ; i < startyear ; i++)
    {
        if(leap(i))
        day += 366 ;
        else day += 365 ;
    }
    for(int i = 1 ; i < startmonth ; i++)
    if(leap(startyear))
    day += leapmon[i] ;
    else day += mon[i] ;
    if(startyear > 1752||(startyear == 1752&&startmonth > 9))
    day -= 11 ;
    return day ;
}
int main()
{
    int t ;
    cin>>t ;
    while(t--)
    {
        int startyear ,startmon ,endyear,endmon ;
        cin>>startyear>>startmon>>endyear>>endmon ;
        int day = sum(startyear,startmon) ;
        int good = 0 ,luck = 0 ;
        if(((day+5)%7 == 1) || ((day+5)%7 == 6)||((day+5)%7 == 0))
        good++ ;
        int j ;
        for(int i = startyear ; i < endyear ; i++)
        {
            i == startyear ? j = startmon : j = 1 ;
            for(  ; j <= 12 ; j++)
            {
                if(leap(i))
                day += leapmon[j] ;
                else day += mon[j] ;
                if(i == 1752&&j == 9)
                day -= 11 ;
                if(((day+5)%7 == 1) || ((day+5)%7 == 6)||((day+5)%7 == 0))
                {good++ ;luck++ ;}
            }
        }
        startyear == endyear ? j = startmon : j = 1 ;
        for( ; j <= endmon ; j++)
        {
            if(leap(endyear))
            day += leapmon[j] ;
            else day += mon[j] ;
            if(endyear == 1752 && j == 9)
            day -= 11 ;
            if(((day+5)%7 == 1) || ((day+5)%7 == 6)||((day+5)%7 == 0))
            {
               if(j != endmon)
               good++ ;
               luck++ ;
            }
        }
        cout<<luck<<" "<<good<<endl  ;
    }
return 0 ;
}
View Code

 

posted on 2013-11-29 21:21  枫、  阅读(496)  评论(0编辑  收藏  举报