收藏 分享(赏)

第22届全国青少年信息学奥林匹克联赛NOIP2016提高组试题day1.doc

上传人:weiwoduzun 文档编号:4145607 上传时间:2018-12-11 格式:DOC 页数:10 大小:190.54KB
下载 相关 举报
第22届全国青少年信息学奥林匹克联赛NOIP2016提高组试题day1.doc_第1页
第1页 / 共10页
第22届全国青少年信息学奥林匹克联赛NOIP2016提高组试题day1.doc_第2页
第2页 / 共10页
第22届全国青少年信息学奥林匹克联赛NOIP2016提高组试题day1.doc_第3页
第3页 / 共10页
第22届全国青少年信息学奥林匹克联赛NOIP2016提高组试题day1.doc_第4页
第4页 / 共10页
第22届全国青少年信息学奥林匹克联赛NOIP2016提高组试题day1.doc_第5页
第5页 / 共10页
点击查看更多>>
资源描述

1、第 1 页 共 10 页第22 届全国青少年信息学奥林匹克联赛CCF-NOIP-2016提高组(复赛)第一试竞赛时间:2016年11月19日8:3012:00题目名称 玩具谜题 天天爱跑步 换教室题目类型 传统型 传统型 传统型目录 toy running classroom可执行文件名 toy running classroom输入文件名 toy.in running.in classroom.in输出文件名 toy.out running.out classroom.out每个测试点时限 1.0秒 2.0秒 1.0秒内存限制 512MB 512MB 512MB测试点数目 20 20 25每

2、个测试点分值 5 5 4提交源程序文件名对于C+语言 toy.cpp running.cpp classroom.cpp对于C语言 toy.c running.c classroom.c对于Pascal语言 toy.pas running.pas classroom.pas编译选项对于C+语言 -lm -lm -lm对于语言 -lm -lm -lm对于Pascal语言注意事项:1文件名(程序名和输入输出文件名)必须使用英文小写。2除非特殊说明,结果比较方式均为忽略行末空格及文末回车的全文比较。3C/C+中函数main()的返回值类型必须是int ,程序正常结束时的返回值必须是0 。4全国统一评

3、测时采用的机器配置为:CPU AMD Athlon(tm) X2 240 processor 2.8GHz,内存 4G,上述时限以此配置为准。5只提供Linux 格式附加样例文件。6评测在NOI Linux下进行。7编译时不打开任何优化选项。第 22届全国青少年信息学奥林匹克联赛提高组(复赛) 第一试 玩具迷题(toy)第 2 页 共 10 页玩具谜题(toy)【问题描述】小南有一套可爱的玩具小人,它们各有不同的职业。有一天,这些玩具小人把小南的眼镜藏了起来。小南发现玩具小人们围成了一个圈,它们有的面朝圈内,有的面朝圈外。如下图:这时singer告诉小南一个谜题:“眼镜藏在我左数第3个玩具小人

4、的右数第1个玩具小人的左数第2 个玩具小人那里。”小南发现,这个谜题中玩具小人的朝向非常关键,因为朝内和朝外的玩具小人的左右方向是相反的:面朝圈内的玩具小人,它的左边是顺时针方向,右边是逆时针方向;而面向圈外的玩具小人,它的左边是逆时针方向,右边是顺时针方向。小南一边艰难地辨认着玩具小人,一边数着:“singer”朝内,左数第3个是archer 。“archer”朝外,右数第 1个是 thinker。“thinker”朝外,左数第2 个是writer。“所以眼镜藏在writer这里!”虽然成功找回了眼镜,但小南并没有放心。如果下次有更多的玩具小人藏他的眼镜,或是谜题的长度更长,他可能就无法找到

5、眼镜了。所以小南希望你写程序帮他解决类似的谜题。这样的谜题具体可以描述为:有n个玩具小人围成一圈,已知它们的职业和朝向。现在第1个玩具小人告诉小南一个包含m条指令的谜题,其中第i条指令形如 “左数/右数第s i个玩具小人” 。你需要输出依次数完这些指令后,到达的玩具小人的职业。【输入格式】从文件toy.in中读入数据。输入的第一行包含两个正整数n,m,表示玩具小人的个数和指令的条数。接下来n行,每行包含一个整数和一个字符串,以逆时针为顺序给出每个玩具小人的朝向和职业。其中0 表示朝向圈内,1 表示朝向圈外。保证不会出现其他的数。字符串长度不超过10且仅由小写字母构成,字符串不为空,并且字符串两

6、两不同。整数和字符串之间用一个空格隔开。第 22届全国青少年信息学奥林匹克联赛提高组(复赛) 第一试 玩具迷题(toy)第 3 页 共 10 页接下来m行,其中第 i行包含两个整数a i,s i,表示第i条指令。若 ai=0,表示向左数s i个人;若ai=1,表示向右数s i个人。保证a i不会出现其他的数,1=s in。【输出格式】输出到文件toy.out 中。输出一个字符串,表示从第一个读入的小人开始,依次数完m条指令后到达的小人的职业。【样例1输入】7 30 singer0 reader1 thinker1 archer0 write1 mogician0 31 10 2【样例1输出】w

7、riter【样例1说明】这组数据就是【题目描述】中提到的例子。【样例2输入】10 101 c0 r0 p1 d1 e1 m1 t1 y1 u0 v1 71 11 40 50 30 11 61 20 80 4【样例2输出】y【子任务】子任务会给出部分测试数据的特点。如果你在解决题目中遇到了困难,可以尝试只解决一部分测试第 22届全国青少年信息学奥林匹克联赛提高组(复赛) 第一试 玩具迷题(toy)第 4 页 共 10 页数据。每个测试点的数据规模及特点如下表:测试点 n m 全朝内 全左数 si=1 职业长度为11 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16= 20

8、 = 103 17 18 X 19 20= 105 = 105X X其中一些简写的列意义如下: 全朝内:若为“” ,表示该测试点保证所有的玩具小人都朝向圈内; 全左数:若为“” ,表示该测试点保证所有的指令都向左数,即对任意的1=i=m ,a i=0; si=1:若为“”,表示该测试点保证所有的指令都只数1 个,即对任意的1=i=m ,s i=1; 职业长度为1:若为“”,表示该测试点保证所有玩具小人的职业一定是一个长度为1的字符串。第22届全国青少年信息学奥林匹克联赛提高组(复赛) 第一试 天天爱跑步(running )第 5 页 共 10 页天天爱跑步(running)【问题描述】小C同学

9、认为跑步非常有趣,于是决定制作一款叫做天天爱跑步的游戏。天天爱跑步是一个养成类游戏,需要玩家每天按时上线,完成打卡任务。这个游戏的地图可以看作一棵包含n个结点和n-1条边的树,每条边连接两个结点,且任意两个结点存在一条路径互相可达。树上结点编号为从1 到n的连续正整数。现在有m个玩家,第 i个玩家的起点为S i,终点为T i。每天打卡任务开始时,所有玩家在第0秒同时从自己的起点出发,以每秒跑一条边的速度,不间断地沿着最短路径向着自己的终点跑去,跑到终点后该玩家就算完成了打卡任务。(由于地图是一棵树,所以每个人的路径是唯一的)小C想知道游戏的活跃度,所以在每个结点上都放置了一个观察员。在结点J

10、的观察员会选择在第W j秒观察玩家,一个玩家能被这个观察员观察到当且仅当该玩家在第W j秒也正好到达了结点J 。小C想知道每个观察员会观察到多少人?注意:我们认为一个玩家到达自己的终点后该玩家就会结束游戏,他不能等待一段时间后再被观察员观察到。即对于把结点J作为终点的玩家:若他在第 Wj秒前到达终点,则在结点J的观察员不能观察到该玩家;若他正好在第W j秒到达终点,则在结点J的观察员可以观察到这个玩家。【输入格式】从文件running.in中读入数据。第一行有两个整数n和m。其中 n代表树的结点数量,同时也是观察员的数量,m 代表玩家的数量。接下来n-1行每行两个整数u和v,表示结点u到结点v

11、有一条边。接下来一行n个整数,其中第J个整数为W j,表示结点J出现观察员的时间。接下来m行,每行两个整数 Si和T i,表示一个玩家的起点和终点。对于所有的数据,保证1=S i,Ti=n,0=W j=n。【输出格式】输出到文件running.out中。输出1行 n个整数,第j个整数表示结点J的观察员可以观察到多少人。【样例1输入】6 32 31 21 44 54 60 2 5 1 2 31 52 6【样例1输出】2 0 0 1 1 1【样例1说明】对于1号点, W1=0,故只有起点为1号点的玩家才会被观察到,所以玩家1 和玩家2被观察到,共2 人被观察到。第22届全国青少年信息学奥林匹克联赛

12、提高组(复赛) 第一试 天天爱跑步(running )第 6 页 共 10 页对于2号点,没有玩家在第2 秒时在此结点,共0人被观察到。对于3号点,没有玩家在第5 秒时在此结点,共0人被观察到。对于4号点,玩家1 被观察到,共1人被观察到。对于5号点,玩家2 被观察到,共1人被观察到。对于6号点,玩家3 被观察到,共1人被观察到。【样例2输入】5 31 22 32 41 50 1 0 3 03 11 45 5【样例2输出】1 2 1 0 1【子任务】每个测试点的数据规模及特点如下表所示。提示:数据范围的个位上的数宇可以帮助判断是哪一种数据类型。测试点编号 n m 约定12 = 991 = 99

13、1所有人的起点等于自己的终点,即S i=Ti3 = 992 = 992 Wj=045 = 993 = 993 无678= 99994 = 99994树退化成一条链,其中1 与2有边, 2与3有边, ,n-1与n有边9101112= 99995 = 99995 所有的S i=113141516= 99996 = 99996 所有的 Ti=1171819= 99997 = 9999720 = 299998 = 299998无【提示】第22届全国青少年信息学奥林匹克联赛提高组(复赛) 第一试 天天爱跑步(running )第 7 页 共 10 页如果你的程序需要用到较大的栈空间(这通常意味着需要较深

14、层数的递归),请务必仔细阅读选手目录下的文档running/stack.pdf,以了解在最终评测时栈空间的限制与在当前工作环境下调整栈空间限制的方法。第22届全国青少年信息学奥林匹克联赛提高组(复赛) 第一试 换教室(classroom )第 8 页 共 10 页换教室(classroom)【问题描述】对于刚上大学的牛牛来说,他面临的第一个问题是如何根据实际情况申请合适的课程。在可以选择的课程中,有2n节课程安排在n个时间段上。在第 i(1=i=n)个时间段上,两节内容相同的课程同时在不同的地点进行,其中,牛牛预先被安排在教室c i上课,而另一节课程在教室d i进行。在不提交任何申请的情况下,

15、学生们需要按时间段的顺序依次完成所有的n节安排好的课程。如果学生想更换第i节课程的教室,则需要提出申请。若申请通过,学生就可以在第i个时间段去教室d i上课,否则仍然在教室c i上课。由于更换教室的需求太多,申请不一定能获得通过。通过计算,牛牛发现申请更换第i节课程的教室时,申请被通过的概率是一个已知的实数ki,并且对于不同课程的申请,被通过的概率是互相独立的。学校规定,所有的申请只能在学期开始前一次性提交,并且每个人只能选择至多m节课程进行申请。这意味着牛牛必须一次性决定是否申请更换每节课的教室,而不能根据某些课程的申请结果来决定其他课程是否申请;牛牛可以申请自己最希望更换教室的m 门课程,

16、也可以不用完这m 个申请的机会,甚至可以一门课程都不申请。因为不同的课程可能会被安排在不同的教室进行,所以牛牛需要利用课间时间从一间教室赶到另一间教室。牛牛所在的大学有v个教室,有e条道路。每条道路连接两间教室,并且是可以双向通行的。由于道路的长度和拥堵程度不同,通过不同的道路耗费的体力可能会有所不同。当第i(1=i=n-1)节课结束后,牛牛就会从这节课的教室出发,选择一条耗费体力最少的路径前往下一节课的教室。现在牛牛想知道,申请哪几门课程可以使他因在教室间移动耗费的体力值的总和的期望值最小,请你帮他求出这个最小值。【输入格式】从文件classroom.in 中读入数据。第一行四个整数n,m,

17、v,e。n表示这个学期内的时间段的数量;m 表示牛牛最多可以申请更换多少节课程的教室;v表示牛牛学校里教室的数量;e表示牛牛的学校里道路的数量。第二行n个正整数,第i(1=i=n)个正整数表示c i。,即第i个时间段牛牛被安排上课的教室;保证1=c i=v。第三行n个正整数,第i(1=i=n)个正整数表示d i,即第 i个时间段另一间上同样课程的教室;保证1=d i=v。第四行n个实数,第i(1=i=n)个实数表示ki,即牛牛申请在第 i个时间段更换教室获得通过的概率。保证0=k i=1。接下来e行,每行三个正整数 aj,b j,w j,表示有一条双向道路连接教室 aj,b j,通过这条道路需

18、要耗费的体力值是w j;保证1=a j,b j=v。保证1=n=2000,0=m=2000,1=v=300,0=e=90000 。保证通过学校里的道路,从任何一间教室出发,都能到达其他所有的教室。保证输入的实数最多包含3位小数。【输出格式】输出到文件classroom.out中。输出一行,包含一个实数,四舍五入精确到小数点后恰好2位,表示答案。你的输出必须和标准输出完全一样才算正确。第22届全国青少年信息学奥林匹克联赛提高组(复赛) 第一试 换教室(classroom )第 9 页 共 10 页测试数据保证四舍五入后的答案和准确答案的差的绝对值不大于4*10-3。(如果你不知道什么是浮点误差,

19、这段话可以理解为:对于大多数的算法,你可以正常地使用浮点数类型而不用对它进行特殊的处理)【样例1输入】3 2 3 32 1 21 2 10.8 0.2 0.51 2 51 3 32 3 1【样例1输出】2.80【样例1说明】所有可行的申请方案和期望收益如下表:申请更换教室的时间段申请通过的时间段 出现的概率 耗费的体力值耗费的体力值的期望无 无 1.0 8 8.01 0.8 41无 0.2 8 4.82 0.2 02无 0.8 8 6.43 0.5 43无 0.5 8 6.01、2 0.16 41 0.64 42 0.04 01、2无 0.16 84.481、3 0.4 01 0.4 43 0

20、.1 41、3无 0.1 82.82、3 0.1 42 0.1 03 0.4 42、3无 0.4 85.2【样例2】见选手目录下的classroom/classroom2.in与classroom/classroom2.ans。【提示】1道路中可能会有多条双向道路连接相同的两间教室。也有可能有道路两端连接的是同一间教室。2请注意区分n,m,v,e的意义,n不是教室的数量,m 不是道路的数量。【子任务】第22届全国青少年信息学奥林匹克联赛提高组(复赛) 第一试 换教室(classroom )第 10 页 共 10 页测试点 n m v 特殊性质1 特殊性质21 = 1 = 1 = 3002 =

21、0 = 203 = 1 = 1004= 2= 2 = 300X X5 = 0 = 20 6 = 1 = 100 7= 3= 2 X X8 = 0 = 300 9 = 1 = 20 10 = 2 = 100 X11= 10= 10 = 300 X 12 = 0 = 20 13 = 1 = 100 X14 = 2 X15= 20= 20 = 300 16 = 0 = 2017 = 1 = 100X X18 = 2 19= 300= 300 = 300 20 = 021 = 1 = 2022 = 223 = 1002425= 2000= 2000 = 300X X特殊性质1:图上任意两点a i,b i(a ibi)间,存在一条耗费体力最少的路径只包含一条道路。特殊性质2:对于所有的1=i=n,k i=1。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 中等教育 > 试题课件

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报