- 浏览: 202458 次
- 性别:
- 来自: 武汉
文章分类
- 全部博客 (137)
- c++ (74)
- c++,算法,回溯 (2)
- DP问题。 (9)
- DP问题,0/1背包问题 (3)
- 数学问题 (6)
- 贪心算法 (10)
- 排序 (16)
- 数据结构 (7)
- 容器 (2)
- 模拟问题 (2)
- 水题 (8)
- 并查集 (3)
- 非技术 (2)
- 素数问题 (1)
- DFS (3)
- 二叉树 (1)
- 递归 (1)
- 图论 (5)
- 最小生成树 (5)
- 最短路径 (6)
- bell_flaod算法 (2)
- hash (3)
- 二分查找 (1)
- 搜索 (5)
- BFS (5)
- STL (3)
- 字符串hash (1)
- 拓扑排序 (1)
- 字典树 (4)
- 哈弗曼树 (1)
- KMP (7)
- 线段树 (9)
- 树状数组 (6)
- 全排列 (2)
- DP问题 (2)
- LCS (1)
- 最长不下降子序列 (2)
- 面试经验 (3)
大致题意: 科普文一篇,文章80%都是无用信息,因为都是常识,但是又不得不看,因为有20%是常人不知道的历史常识。 定义: Goog month : 该月第一个工作日为星期一的月份 Luckly month: 该月最后一个工作日为星期五的月份 问: 给定一个Gregorian Calendar格里高公历的 时间闭区间(就是包括端点的年月了) 【开始年、月】~【结束年、月】 在这个时间区间内,有多少个Goog month,有多少个Luckly month 文章要点: Gregorian Calendar格里高公历 就是现在广泛使用公历(西历),下面简称GC GC的起始日期为 1年1月1号,该日为星期六 GC平年有365天,闰年366天(2月多1天) GC有12个月,各月的天数和现在的使用的西历一致 GC在1582年之前(不包括1582),若该年份能被4整除,则为闰年 GC在1582年之后(包括1582),判断闰年的标准(满足下面随便一个): (1) 能被4整除,但不能被100整除; (2) 能被400整除。 由于历史原因,GC规定1700年无条件为闰年 由于历史原因,GC规定1752年9月3日~13日共11天不存在,即1752年9月只有19天 GC一星期有7天,排序为Sun,Mon,Tue,Wed,Thu,Fri,Sat,和现在的星期一致,其中Mon到Fri为工作日,Sun和Sat为休息日 解题思路: 直接模拟就OK了,水题 先做一个判断闰年的函数 leap() 输入时间区间的 起始年sy月sm 和 终止年ey月em 后 先计算1年1月到sy年sm-1月(若sm=1,则计算到sy-1年12月)的天数day 注意此时day的天数刚好计算到sm-1月的最后一天 若day+1,则恰好进入所输入的时间区间【开始年、月】~【结束年、月】的第一天 计算day时要注意: (1) 1582年前后闰年判断标准改变了 (2) 1700无条件闰年 (3) 1752年9月少了11天 判断第day天是星期几: 由于1年1月1号为星期六,一星期有7天, 因此 (day+5)%7就能计算第day天是星期几。 不能直接day%7,day%7就是默认1年1月1号为星期日,至于为什么要先+5,这个不难推导,读者自己想想就明白了 判断某月是不是Good month和Luckly month: 计算天数day后,令day++,进入sm的1号 此时判断sm的1号是不是为Good month,使用上面给出计算第day天是星期几的方法,若 1号为星期日(0)、星期六(6)或星期一(1),则该月为Good month 从sm月开始,把天数day逐月递增,逐月判断该月是否为Good month,判断方法都是一样的。 不难发现,若第k月为Good month,则第k-1月必定为Luckly month,因此两个计数器同时增加即可。 注意3点: (1) 边界:若sm为Good month,计数器good++,但计数器luck不变,因为sm-1月不在时间区间内。 若计算到em为Good month,则计数器luck++,good不变,因为day一开始就+1了,当day逐月递增到em时,实则day此时为第em+1月的1号,此时判断的是em+1月是否为Good month,若是,则第em月为Luckly month,但em+1月在时间区间内,不计入计数器 (2) 逐月递增时,若到达1752年9月,要 减11天 (3) 闰年平年的月份天数不同 代码如下: #include<iostream>
using namespace std;
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}; //星期
bool leap(int year); //判断year是否为闰年
int ComputeDay(int y,int m); //计算从第1年1月1日到第y年m-1月的总天数+1 (即只包括第m个月的第一天)
int main(int i,int j,int* pm)
{
int test;
cin>>test;
for(int t=0;t<test;t++)
{
int ys,ms,ye,me;
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调整
/*计算从ys年ms+1开始 到ye-1年的月份是否为good month*/
for(i=ys;i<ye;i++)
{
if(leap(i))
pm=Lmonth;
else
pm=Month;
if(i==ys)
j=ms;
else
j=1;
for(;j<=12;j++)
{
day+=*(pm+j);
if(i==1752 && j==9)
day-=11;
//由于day开始时+1缘故,当j时,计算的是第j+1月是否为good month
if(((day+5)%7<=Mon) || ((day+5)%7==Sat)) //计算j+1月1号为星期几,判断是否为good month
{
good++;
luck++; //当j+1月为good month,j月必为luck month
}
}
}
/*计算第ye年的good month*/
if(leap(i))
pm=Lmonth;
else
pm=Month;
if(i==ys) //若ye==ys
j=ms;
else
j=1;
for(;j<=me;j++)
{
day+=*(pm+j);
if(i==1752 && j==9)
day-=11;
//由于day开始时+1缘故,当j时,计算的是第j+1月是否为good month
if(((day+5)%7<=Mon) || ((day+5)%7==Sat)) //计算j+1月1号为星期几,判断是否为good month
{
if(j!=me)
good++;
luck++; //当j+1月为good month,j月必为luck month
}
}
cout<<luck<<' '<<good<<endl;
}
return 0;
}
bool leap(int year) //判断year是否为闰年
{
if(year<1582)
return !(year%4); //当year<1582时,只要能被4整除就是闰年
else
{
if(year==1700) //当year=1700时,历史原因,无条件为闰年
return true;
if((!(year%4)&&(year%100)) || !(year%400)) //当year>=1582时,能被4整除且不被100整除为闰年
return true; //或能被400整除时为闰年
}
return false;
}
int ComputeDay(int y,int m) //计算从第1年1月1日到第y年m-1月的总天数+1 (即只包括第m个月的第一天)
{ //"+1"是为了使从当月末变为下月初
int i,j,day=1;
for(i=1;i<y;i++)
if(leap(i))
day+=366;
else
day+=365;
for(j=1;j<m;j++)
if(leap(i))
day+=Lmonth[j];
else
day+=Month[j];
if(y>1752)
day-=11;
else if(y==1752 && m>9)
day-=11;
return day;
}
发表评论
-
虚函数、纯虚函数、虚基类、抽象类、虚函数继承、虚继承
2013-08-29 14:34 842虚函数:虚函数是C++中用于实现多态(polymorphis ... -
排序算法总结
2013-05-17 11:00 843选择排序、快速排序、希尔排序、堆排序不是稳定的排序算法, ... -
poj 3122
2012-12-11 19:51 870题意:作者要开一个生日party,他现在拥有n块高度都为1 ... -
poj 3273
2012-12-11 16:49 987题意:给你天数n,和每天需要花的钱,让你把这些天分成m份(每份 ... -
字典树学习材料
2012-05-30 14:29 970字典树,又称单词查找树,Trie树,是一种树形结构,典型应 ... -
poj 1159
2012-05-28 19:08 1446题目大意:给你一段字符串,让你求出在中间最少加入几个字符 ... -
poj 3176
2012-05-28 14:47 1019大致题意: 输入一个n层的三角形,第i层有i个数,求从第 ... -
poj 1260
2012-05-28 09:54 1615题意解释: 有n个等级的珠宝,等级依次升高,等级越高价钱越高 ... -
poj 1836
2012-05-28 09:22 2715是POJ2533的扩展题。题意不难,令到原队列 ... -
poj 2533
2012-05-26 15:36 1274在做这道题目之前,首先让我们了解一下什么是LIS算法,LIS俗 ... -
poj 3267
2012-05-26 09:43 804从程序可以看出,第i个位置到L所删除的字符数,总是先取最坏情况 ... -
poj 1276
2012-05-25 16:20 2397题意: 这道题的意思是给你一堆钱,各种面值的都有,比 ... -
poj 1094
2012-05-25 13:54 1108题意:给出字母个数,和有限个有序对(a<b)求出能确定字 ... -
poj 3007
2012-05-14 10:21 994大致题意: 给定一个字符串,从任意位置把它切为两半, ... -
poj 3096
2012-05-10 21:09 1012题意: 定义D-pairs表示取字符串s中相距为D的两个字母 ... -
poj 1426
2012-04-26 20:11 2171大致题意: 给出一个整数n,(1 <= n <= ... -
poj 1797
2012-04-24 15:05 1627题目大意是就是何处一个图,n个顶点和m条边,每个边都有最大承载 ... -
poj 1338
2012-04-23 10:20 1260题意:题目意思是求由2,3,5的乘积组成的数从大到小排列,从1 ... -
poj 2021
2012-04-19 15:00 951题意:Ted今年100岁,给出n对他家族的关系:“父 ... -
poj 1656
2012-04-19 10:07 1121题目要求:一道纯的模拟题目。 直接上代码: ...
相关推荐
【标题】"POJ3393 - 幸运与好月份:格里高利历" 这个编程题目来源于北京大学的在线判题系统POJ(Problem Online Judge),编号为3393。题目主要涉及计算机科学中的算法设计和实现,特别是日期处理和数学计算。在...
* 较为复杂的模拟题的训练:例如 poj3393、poj1472、poj3371、poj1027、poj2706。 2. 图算法: * 差分约束系统的建立和求解:例如 poj1201、poj2983。 * 最小费用最大流:例如 poj2516、poj2516、poj2195。 * ...
- 复杂的模拟题:如`poj3393, poj1472`。 - **图算法** - 差分约束系统:如`poj1201, poj2983`。 - 最小费用最大流:如`poj2516, poj2195`。 - **数据结构** - 线段树:如`poj2528, poj2828`。 - RMQ(区间...
- **例题**:poj3393, poj1472, poj3371, poj1027, poj2706 - **解释**:特殊优化技巧通常涉及特定问题的优化算法,如位运算、快速幂等。 ### 总结 POJ平台上的题目涵盖了广泛的技术领域,包括算法、数据结构、...
- (poj3393, poj1472, poj3371, poj1027, poj2706):针对竞赛中的复杂问题提供深入的学习资源。 ### 八、图论进阶 1. **图的高级特性**: - (poj1201, poj2983):更深层次的图论概念和性质。 2. **特殊图结构**...
2. **复杂的模拟题**:poj3393、poj1472等训练选手处理复杂逻辑和模拟问题的能力。 3. **图算法的深化**:如差分约束系统、最小费用最大流、双连通分量、强连通分支及其缩点、图的割边和割点、最小割模型等。poj1201...
- POJ 3393、POJ 1472:自定义数据结构的设计与实现。 ### 图论 #### 连通性 - **题目示例**: - POJ 1201、POJ 2983:图的连通性分析。 #### 强连通分量 - **题目示例**: - POJ 2186:强连通分量的识别与...
2. **自定义数据结构**:创建和使用自定义的数据结构和算法(poj3393, poj1472, poj3371, poj1027, poj2706)。 ### 十一、进阶图论 1. **图的高级操作**:如图的连通性分析(poj1201, poj2983)。 2. **特殊图...
- poj3393 - poj1472 - poj3371 - poj1027 - poj2706 - poj3434 - **应用场景**:适用于解决实际问题的模拟。 **3. 差分约束系统** - **定义**:建立和求解差分约束系统。 - **示例题目**: - poj1201 - ...
2. **复杂模拟题**:解决更实际和复杂的问题,如POJ3393、1472、3371、1027和2706。 3. **差分约束系统**:建立和求解线性约束问题,如POJ1201和2983。 4. **最小费用最大流**:在考虑费用的情况下寻找最大流,如POJ...
+ poj3393, poj1472, poj3371, poj1027, poj2706 二、图算法 * 差分约束系统的建立和求解 + poj1201, poj2983 * 最小费用最大流 + poj2516, poj2516, poj2195 * 双连通分量 + poj2942 * 强连通分支及其缩点 +...
例如,POJ3096和POJ3007是C++标准模版库的应用,而POJ3393和POJ1472则是较为复杂的模拟题的训练。 该算法目录提供了一个系统的算法学习框架,涵盖了初级、中级和高级算法,旨在帮助选手快速提高算法能力,提高在 ...
(2) 较为复杂的模拟题的训练:poj3393, poj1472, poj3371, poj1027, poj2706 (3) 差分约束系统的建立和求解:poj1201, poj2983 (4) 最小费用最大流:poj2516, poj2516, poj2195 (5) 双连通分量:poj2942 (6) 图的割...
2. 复杂模拟题:如poj3393、poj1472等。 3. 差分约束系统、最小费用最大流、双连通分量和强连通分支等更高级的图算法。 以上就是ACM算法的详细总结,涵盖了基础到中级的各种算法和数据结构,它们是解决复杂问题的...
1. poj3096、poj3007、poj3393、poj1472、poj3371、poj1027、poj2706 2. poj1201、poj2983、poj2516、poj2516、poj2195 3. poj2942、poj2186、poj3352 4. poj2528、poj2828、poj2777、poj2886、poj2750 通过学习和...
例题:poj3393、poj1472、poj3371、poj1027、poj2706。 二、图算法 * 差分约束系统的建立和求解:差分约束系统是指用于解决图的约束问题的算法。例题:poj1201、poj2983。 * 最小费用最大流:最小费用最大流是指在...
- **复杂模拟题**:通过实践增强模拟题解题能力,如Poj3393、Poj1472等。 - **图算法**:深入学习差分约束系统、最小费用最大流、双连通分量等。 - **数据结构**:掌握线段树、静态二叉检索树、树状数组等高级...
2. 更复杂的模拟题:如poj3393。 3. 差分约束系统的建立与求解。 4. 最小费用最大流。 5. 双连通分量和强连通分支的缩点。 这个训练方案覆盖了ACM竞赛所需的基础知识和进阶技能,对于提升编程思维和算法能力有着极...
- POJ 3393, POJ 1472, POJ 3371, POJ 1027, POJ 2706 模拟是一种解决问题的方法,通过按照题目描述的过程进行操作来求解问题。 ### 其他 1. **系统和网络** - POJ 1201, POJ 2983 这些题目可能涉及到计算机...