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[] = {,,,,,,,,,,,,} ;
int leapmon[] = {,,,,,,,,,,,,} ;
bool leap(int n)
{
if(n < )
{
if(n % == )
return true ;
return false ;
}
else
{
if((n% == &&n%!=)||(n% == )||n==)
return true;
return false ;
}
}
int sum(int startyear,int startmonth)
{
int day = ;
for(int i = ; i < startyear ; i++)
{
if(leap(i))
day += ;
else day += ;
}
for(int i = ; i < startmonth ; i++)
if(leap(startyear))
day += leapmon[i] ;
else day += mon[i] ;
if(startyear > ||(startyear == &&startmonth > ))
day -= ;
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 = ,luck = ;
if(((day+)% == ) || ((day+)% == )||((day+)% == ))
good++ ;
int j ;
for(int i = startyear ; i < endyear ; i++)
{
i == startyear ? j = startmon : j = ;
for( ; j <= ; j++)
{
if(leap(i))
day += leapmon[j] ;
else day += mon[j] ;
if(i == &&j == )
day -= ;
if(((day+)% == ) || ((day+)% == )||((day+)% == ))
{good++ ;luck++ ;}
}
}
startyear == endyear ? j = startmon : j = ;
for( ; j <= endmon ; j++)
{
if(leap(endyear))
day += leapmon[j] ;
else day += mon[j] ;
if(endyear == && j == )
day -= ;
if(((day+)% == ) || ((day+)% == )||((day+)% == ))
{
if(j != endmon)
good++ ;
luck++ ;
}
}
cout<<luck<<" "<<good<<endl ;
}
return ;
}

POJ 3393 Lucky and Good Months by Gregorian Calendar的更多相关文章

  1. POJ 3393 Lucky and Good Months by Gregorian Calendar 模拟题

    题目:http://poj.org/problem?id=3393 不多说了,简单模拟题,因为粗心写错了两个字母,导致错了N遍,模拟还是一贯的恶心,代码实在不想优化了,写的难看了点.. #includ ...

  2. poj 3393 Lucky and Good Months by Gregorian Calendar(模拟)

    题目:http://poj.org/problem?id=3393一道题目挺长的模拟题,参考了网上大神的题解. #include <iostream> #include <cstdi ...

  3. POJ 3393:Lucky and Good Months by Gregorian Calendar 年+星期 模拟

    Lucky and Good Months by Gregorian Calendar Time Limit: 1000MS   Memory Limit: 65536K Total Submissi ...

  4. Lucky and Good Months by Gregorian Calendar - POJ3393模拟

    Lucky and Good Months by Gregorian Calendar Time Limit: 1000MS Memory Limit: 65536K Description Have ...

  5. Lucky and Good Months by Gregorian Calendar(poj 3393)

    大致题意: 科普文一篇,文章80%都是无用信息,因为都是常识,但是又不得不看,因为有20%是常人不知道的历史常识. 定义: Goog month : 该月第一个工作日为星期一的月份 Luckly mo ...

  6. Lucky and Good Months by Gregorian Calendar(模拟)

    http://poj.org/problem?id=3393 好大的一道模拟题,直接当阅读理解看了.下面是大神写的题意,解释的好详细. 定义: Goog month : 该月第一个工作日为星期一的月份 ...

  7. 三部曲二(基本算法、动态规划、搜索)-1003-Lucky and Good Months by Gregorian Calendar

    模拟加阅读题......虽然很多事常识性的知识,但也有许多不知道的知识,关键是不读不知道那些是已经知道的那些不是,许多重要的信息零散的分布在一大坨英文里,读起来很痛苦......自己读了一遍,读的晕晕 ...

  8. poj 2346 Lucky tickets(区间dp)

    题目链接:http://poj.org/problem?id=2346 思路分析:使用动态规划解法:设函数 d( n, x )代表长度为n且满足左边n/2位的和减去右边n/2位的和为x的数的数目. 将 ...

  9. poj3393[模拟题]

    Lucky and Good Months by Gregorian Calendar Time Limit: 1000MS   Memory Limit: 65536K Total Submissi ...

随机推荐

  1. C# @符号的多种使用方法

    1.限定字符串用 @ 符号加在字符串前面表示其中的转义字符“不”被处理.如果我们写一个文件的路径,例如"D:/文本文件"路径下的text.txt文件,不加@符号的话写法如下:str ...

  2. C# 3.0 特性之扩展方法

    今天,我们来聊一聊C#的扩展方法. C# 3.0中为我们提供了一个新的特性—扩展方法.什么是扩展方法呢?我们看一下MSDN的注解: 扩展方法使您能够向现有类型“添加”方法,而无需创建新的派生类型.重新 ...

  3. (转)IDG副总裁楼军:顶级VC青睐什么样的创业者

    学习能力是创业者的第一能力 创业者首先要有格局观和很强的学习能力. 具体什么意思?比如说去年IDG投了一个做C2C平台的海淘项目,创始人之前其实是帮他爱人做海淘代购.他爱人是一个代购买手,赚得还不错, ...

  4. L008-oldboy-mysql-dba-lesson08

    L008-oldboy-mysql-dba-lesson08 xtrabackup安装 [root@web01 installer]# wget https://www.percona.com/dow ...

  5. linux与windows共享剪贴板(clipboard)

    linux与windows共享剪贴板(clipboard)的方法 先说两句废话,其实linux和windows之间不需要共享剪贴板,直接在putty中,按住SHIFT+鼠标选择就可以了. 但是作为一种 ...

  6. jQuery网页元素拖拽插件

    效果说明:配合已有CSS样式,载入插件后,网页元素可以随意在窗口内拖拽,设置了原位置半透明和拖拽半透明的效果选项,可根据需要选择.另外,当页面上有多个可拖拽元素时,可以载入另外一个用于设置z-inde ...

  7. 关于socket阻塞与非阻塞情况下的recv、send、read、write返回值(转载)

    1.阻塞模式与非阻塞模式下recv的返回值各代表什么意思?有没有区别?(就我目前了解阻塞与非阻塞recv返回值没有区分,都是 <0:出错,=0:连接关闭,>0接收到数据大小,特别:返回值  ...

  8. pdf转chm的实现方法

    相比pdf, CHM电子书在Windows系统下不需要安装额外的浏览器即可进行阅读,其内容是基于浏览器的风格,更容易被用户所接受.而且, 具有更强大的功能配置,比如可提供强大的全文搜索.索引.书签等的 ...

  9. J2EE中文乱码处理

    在JAVA WEB开发的过程中,经常会遇到中文乱码的情况,中文乱码主要是在浏览器与服务器交互传递数据的时候发生的.对于这个棘手的问题,我参考(韩顺平老师)视频将处理方法总结与此,供自己以及大家开发的时 ...

  10. (转载)用SQL语句创建Access表

    <来源网址:http://www.delphifans.com/infoview/Article_220.html>用SQL语句创建Access表 很久以前弄的,用了一天的时间,没有什么技 ...