节日(CCF试题)
试题名称: 节日
时间限制: 1.0s
内存限制: 256.0MB
问题描述
有一类节日的日期并不是固定的,而是以“a月的第b个星期c”的形式定下来的,比如说母亲节就定为每年的五月的第二个星期日。
现在,给你a,b,c和y1, y2(1850 ≤ y1, y2 ≤ 2050),希望你输出从公元y1年到公元y2年间的每年的a月的第b个星期c的日期。
提示:关于闰年的规则:年份是400的整数倍时是闰年,否则年份是4的倍数并且不是100的倍数时是闰年,其他年份都不是闰年。例如1900年就不是闰年,而2000年是闰年。
为了方便你推算,已知1850年1月1日是星期二。
输入格式
输入包含恰好一行,有五个整数a, b, c, y1, y2。其中c=1, 2, ……, 6, 7分别表示星期一、二、……、六、日。
输出格式
对于y1和y2之间的每一个年份,包括y1和y2,按照年份从小到大的顺序输出一行。
如果该年的a月第b个星期c确实存在,则以"yyyy/mm/dd"的格式输出,即输出四位数的年份,两位数的月份,两位数的日期,中间用斜杠“/”分隔,位数不足时前补零。
如果该年的a月第b个星期c并不存在,则输出"none"(不包含双引号)。
样例输入
5 2 7 2014 2015
样例输出
2014/05/11
2015/05/10
评测用例规模与约定
这个可是标准日历,从日历显示中我们可以知道,2016年1月的第一个星期的星期五是1月1号,那么第一个星期还会存在星期1,2,3,4吗?不可能吧,因为2016年的1月1号是从第一个星期的周五开始的。所以说如果输入:1 1 4 2016 2016,那么会输出"none"。对不对,对不对,对不对,同志们,正常理解应该是这样的吧。#include "stdafx.h"
#include <iostream>
#include <stdio.h>
using namespace std;
const int YEAR = ;
int flag = ;
//平年和闰年的月份所含的天数
//daysOfMonth[0][]表示平年月份的天数
//daysOfMonth[1][]表示闰年月份的天数
int daysOfMonth[][] =
{
{ , , , , , , , , , , , , },
{ , , , , , , , , , , , , }
}; //判断是否为闰年
void judgeIsLeapYear(int year)
{
if ((year % == ) || (year % == && year % != ))
flag = ;
else
flag = ;
} int cmpDays(int y, int m)
{
int days = ;
for (int i = YEAR; i < y; i++)
{
judgeIsLeapYear(i);
if (flag == )
days += ;
else
days += ;
}
judgeIsLeapYear(y);
for (int i = ; i <= m; i++)
days += daysOfMonth[flag][i-];
return days;
} int main()
{
int a, b, c, y1, y2;
int d1, d2;
int dth;//每月一号是星期几
while (scanf("%d%d%d%d%d", &a, &b, &c, &y1, &y2) != EOF)
{
for (int i = y1; i <= y2; i++)
{
d1 = cmpDays(i, a);//与1850年1月1日相差的天数
dth = d1 % + ;//当前a月1号是星期几
if (dth == )
dth = ;
//计算a月第b个星期星期c的具体日期
d2 = (b - ) * - dth + c + ; if (b == && c<dth || d2 > daysOfMonth[flag][b])
{
printf("none\n");
continue;
} if (d2 <= daysOfMonth[flag][a])
printf("%d/%02d/%02d\n", i, a, d2); }
}
return ;
}
绞尽脑汁了,我擦,修改一下,这个还是看的网上的一篇文章进行修改的,原来第一个星期是存在歧义的。例如上面给的例子,2016年1月1号是周五,那么第一个星期的周四、周三、周二、周日要从下周开始算起,才是第一周。
卧槽,真是一道废题啊,拜拜花费了那么多时间。在此更正本篇文章,以免更多人误解。
#include "stdafx.h"
#include <iostream>
#include <stdio.h>
using namespace std;
const int YEAR = ;
int flag = ;
//平年和闰年的月份所含的天数
//daysOfMonth[0][]表示平年月份的天数
//daysOfMonth[1][]表示闰年月份的天数
int daysOfMonth[][] =
{
{ , , , , , , , , , , , , },
{ , , , , , , , , , , , , }
}; //判断是否为闰年
void judgeIsLeapYear(int year)
{
if ((year % == ) || (year % == && year % != ))
flag = ;
else
flag = ;
} int cmpDays(int y, int m)
{
int days = ;
for (int i = YEAR; i < y; i++)
{
judgeIsLeapYear(i);
if (flag == )
days += ;
else
days += ;
}
judgeIsLeapYear(y);
for (int i = ; i <= m; i++)
days += daysOfMonth[flag][i-];
return days;
} int main()
{
int a, b, c, y1, y2;
int d1, d2;
int count;
int dth;//每月一号是星期几
while (scanf("%d%d%d%d%d", &a, &b, &c, &y1, &y2)!= EOF)
{
for (int i = y1; i <= y2; i++)
{
d1 = cmpDays(i, a);//与1850年1月1日相差的天数
dth = d1 % + ;//当前a月1号是星期几 //计算a月第b个星期星期c的具体日期
//如果当前输入的星期c小于dth表示,第一周的星期c要从下一周算起。
if (c < dth)
count = ;
else
count = ;
d2 = - dth + (b - count) * + c; if (d2 <= daysOfMonth[flag][a])
printf("%d/%02d/%02d\n", i, a, d2);
else
printf("none\n");
}
} return ;
}
给出本人的提交记录:,尼玛都是泪啊,希望以后考试不要出现这样有歧义的题了,卡死人了!

节日(CCF试题)的更多相关文章
- CCF试题:高速公路(Targin)
问题描述 某国有n个城市,为了使得城市间的交通更便利,该国国王打算在城市之间修一些高速公路,由于经费限制,国王打算第一阶段先在部分城市之间修一些单向的高速公路. 现在,大臣们帮国王拟了一个修高速公路的 ...
- CCF 试题编号: 201909-4 试题名称: 推荐系统
这题是stl的综合应用,map要想快,直接上unordered_map,这样查询接近O(1),是不是很嗨皮. 思路其实还是很简单的,type+id做个Hash,由于set.insert的第一个返回值是 ...
- CCF认证历年试题
CCF认证历年试题 不加索引整理会死星人orz 第一题: CCF201712-1 最小差值(100分) CCF201709-1 打酱油(100分) CCF201703-1 分蛋糕(100分) CCF2 ...
- CCF CSP 201503-3 节日
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201503-3 节日 问题描述 有一类节日的日期并不是固定的,而是以“a月的第b个星期c”的形 ...
- CCF 模拟试题——出现次数最多的数 官方答案解析及自己写的正确答案
前几天知道的CCF计算机职业资格认证考试,觉得好像比软考含金量高一些,就去了解了一下,做了模拟试题中的 “出现次数最多的数” 这道题,我的算法和官方答案算法不同,个人觉得觉得官方的好一点,没那么繁琐, ...
- CCF计算机软件能力认证试题练习:201912-5 魔数
CCF计算机软件能力认证试题练习:201912-5 魔数 前置知识:BFS,线段树等 \(f(x) = (x\%A)\%B\) 这个函数值的和直接用线段树维护是不太行的(也可能是我不知道),后来想了很 ...
- CCF 节日
问题描述 有一类节日的日期并不是固定的,而是以"a月的第b个星期c"的形式定下来的,比如说母亲节就定为每年的五月的第二个星期日. 现在,给你a,b,c和y1, y2(1850 ≤ ...
- CCF真题之节日
201503-3 问题描述 有一类节日的日期并不是固定的,而是以“a月的第b个星期c”的形式定下来的,比如说母亲节就定为每年的五月的第二个星期日. 现在,给你a,b,c和y1, y2(1850 ≤ y ...
- ccf练习---节日
问题描述 有一类节日的日期并不是固定的,而是以“a月的第b个星期c”的形式定下来的,比如说母亲节就定为每年的五月的第二个星期日. 现在,给你a,b,c和y1, y2(1850 ≤ y1, y2 ≤ 2 ...
随机推荐
- 网络编程之TCP/UDP及其流程比较(转)
TCP与UDP的区别 基于连接与无连接 对系统资源的要求(TCP较多,UDP少) UDP程序结构较简单 流模式与数据报模式TCP保证数据正确性,UDP可能丢包TCP保证数据顺序,UDP不保证 具体编程 ...
- 【Unity3D游戏开发】NGUI之DrawCall数量 (四)
看了非常多关于NGUI drawCall的文章.见得比較多的一个观点是:一个 Atlas 相应一个Drawcall. 但事实上NGUI内部有自己的一套对DrawCall的处理规则. 相关的规则有: 1 ...
- LINUX下添加磁盘空间的方法详解
给Linux系统添加磁盘空间在工作会经常遇到. 在添加第二块磁盘一般系统默认为hdb(IDE硬盘)sdb(SCSI 硬盘),以hdb为例. linux-isep:~ # fdisk /dev/hdb ...
- 通过GUID生成可持久化的PID
byte[] buffer = Guid.NewGuid().ToByteArray(); ); GUID是微软针对UUID的实现,直接生成会大于long类型的最大长度. 但只要转换一下即可
- Volley 解析
Volley Request处理流程 RequestQueue类中有三个基本的队列.调用RequestQueue.add(request)增加的请求会先增加mCacheQueue(优先级堵塞队列)由C ...
- Solr学习之三 solr配置说明之一
严格来说,我这篇内容,主要是根据Solr in Action关于配置的说明,以及参考Solr的wiki写的算是读书笔记吧,所有的图片默认来自Solr in Action这本书. 这本书我觉得对学习So ...
- python map函数的使用
python2 中的map函数返回列表 python3 中的map函数返回迭代器 >>>def square(x) : # 计算平方数 ... return x ** 2 ... & ...
- tomcat 8 加 struts2的 java.lang.NoSuchFieldException: resourceEntries
google发现已经有人把这个bug提交给了apache,issue地址,具体原因就是 Tomcat8 introduce super class WebappClassLoaderBase and ...
- gson 转换 List<Map> 注意事项
如果list泛型显示指定Map类型, 这时的Map 不能直接转换为 jre自带的 map类型 gson封装了 StringMap 进行转换
- Java程序员应该了解的10个设计原则
引用: http://www.cnblogs.com/leehongee/archive/2012/03/18/2404760.html 面向对象设计原则是OOPS(Object-Oriented P ...