1、CCF全国信息学奥林匹克联赛(NOIP2 0 1 5)复赛第1页共8页。CCF全 国 信 息 学 奥 林 匹 克 联 赛 ( NOIP2015) 复 赛普及组(请选手务必仔细阅读本页内容)一、题目概况中文题目名称金币扫雷游戏求和推销员英文题目与子目录名coin mine sum salesman可执行文件名coin mine sum salesman输入文件名coin.in mine.in sum.in salesman.in输出文件名coin.out mine.out sum.out salesman.out每个测试点时限1秒测试点数目1 0每个测试点分值1 0附加样例文件有结果比较方式全文
2、比较(过滤行末空格及文末回车)题目类型传统运行内存上限1 2 8 M二、提交源程序文件名对于C+语言coin.cpp mine.cpp sum.cpp salesman.cpp对于C语言coin.c mine.c sum.c salesman.c对于Pascal语言coin.pas mine.pas sum.pas salesman.pas四、注意事项:1、文件名(程序名和输入输出文件名)必须使用英文小写。2、C/C+中函数main()的返回值类型必须是int,程序正常结束时的返回值必须是0。3、全国统一评测时采用的机器配置为:CPU AMD Athlon(tm) II x2 2 4 0 pr
3、ocessor,2 .8 GHz,内存4 G,上述时限以此配置为准。4、只提供Linux格式附加样例文件。5、特别提醒:评测在当前最新公布的NOI Linux下进行,各语言的编译器版本以其为准。CCF全国信息学奥林匹克联赛(NOIP2 0 1 5)复赛第2页共8页。1 .金币(coin.cpp/c/pas)【问题描述】国王将金币作为工资,发放给忠诚的骑士。第一天,骑士收到一枚金币;之后两天(第二天和第三天),每天收到两枚金币;之后三天(第四、五、六天),每天收到三枚金币;之后四天(第七、八、九、十天),每天收到四枚金币;这种工资发放模式会一直这样延续下去:当连续N天每天收到N枚金币后,骑士会在
4、之后的连续N+1天里,每天收到N+1枚金币。请计算在前K天里,骑士一共获得了多少金币。【输入格式】输入文件名为coin.in。输入文件只有1行,包含一个正整数K,表示发放金币的天数。【输出格式】输出文件名为coin.out。输出文件只有1行,包含一个正整数,即骑士收到的金币数。【输入输出样例1】coin.in coin.out6 1 4见选手目录下的coin/coin1 .in和coin/coin1 .ans。【输入输出样例1说明】骑士第一天收到一枚金币;第二天和第三天,每天收到两枚金币;第四、五、六天,每天收到三枚金币。因此一共收到1 +2 +2 +3 +3 +3 =1 4枚金币。【输入输出
5、样例2】coin.in coin.out1 0 0 0 2 9 8 2 0见选手目录下的coin/coin2 .in和coin/coin2 .ans。【数据说明】对于1 0 0 %的数据,1K1 0 ,0 0 0。CCF全国信息学奥林匹克联赛(NOIP2 0 1 5)复赛第3页共8页。2 .扫雷游戏(mine.cpp/c/pas)【问题描述】扫雷游戏是一款十分经典的单机小游戏。在n行m列的雷区中有一些格子含有地雷(称之为地雷格),其他格子不含地雷(称之为非地雷格)。玩家翻开一个非地雷格时,该格将会出现一个数字提示周围格子中有多少个是地雷格。游戏的目标是在不翻出任何地雷格的条件下,找出所有的非地
6、雷格。现在给出n行m列的雷区中的地雷分布,要求计算出每个非地雷格周围的地雷格数。注:一个格子的周围格子包括其上、下、左、右、左上、右上、左下、右下八个方向上与之直接相邻的格子。【输入格式】输入文件名为mine.in。输入文件第一行是用一个空格隔开的两个整数n和m,分别表示雷区的行数和列数。接下来n行,每行m个字符,描述了雷区中的地雷分布情况。字符*表示相应格子是地雷格,字符?表示相应格子是非地雷格。相邻字符之间无分隔符。【输出格式】输出文件名为mine.out。输出文件包含n行,每行m个字符,描述整个雷区。用*表示地雷格,用周围的地雷个数表示非地雷格。相邻字符之间无分隔符。【输入输出样例1】m
7、ine.inmine.out33*?*?*102211*1见选手目录下的mine/mine1 .in和mine/mine1 .ans。【输入输出样例2】mine.inmine.out23?*?*?2*1*21见选手目录下的mine/mine2 .in和mine/mine2 .ans。【输入输出样例3】见选手目录下的mine/mine3 .in和mine/mine3 .ans。【数据说明】CCF全国信息学奥林匹克联赛(NOIP2 0 1 5)复赛第4页共8页。对于1 0 0 %的数据,1n1 0 0,1m1 0 0。3 .求和(sum.cpp/c/pas)【问题描述】一条狭长的纸带被均匀划分出了
8、n个格子,格子编号从1到n。每个格子上都染了一种颜色攰攰(用1,m当中的一个整数表示),并且写了一个数字。5 5 3 2 2 2编号1 2 3 4 5 6定义一种特殊的三元组:(x, y, z),其中x,y,z都代表纸带上格子的编号,这里的三元组要求满足以下两个条件:1 . ,都是整数,= 2 . 攰攰=攰攰满足上述条件的三元组的分数规定为(x+z)(+)。整个纸带的分数规定为所有满足条件的三元组的分数的和。这个分数可能会很大,你只要输出整个纸带的分数除以1 0 ,0 0 7所得的余数即可。【输入格式】输入文件名为sum.in。CCF全国信息学奥林匹克联赛(NOIP2 0 1 5)复赛第5页共
9、8页。第一行是用一个空格隔开的两个正整数和,代表纸带上格子的个数,代表纸带上颜色的种类数。第二行有个用空格隔开的正整数,第个数字代表纸带上编号为的格子上面写的数字。第三行有个用空格隔开的正整数,第个数字攰攰代表纸带上编号为的格子染的颜色。【输出格式】输出文件名为sum.out。共一行,一个整数,表示所求的纸带分数除以1 0 ,0 0 7所得的余数。【输入输出样例1】sum.insum.out6255322222112182见选手目录下的sum/sum1 .in和sum/sum1 .ans。【输入输出样例1说明】纸带如题目描述中的图所示。所有满足条件的三元组为:(1 ,3 ,5 ),(4 ,5
10、,6 )。所以纸带的分数为(1 +5 )(5 +2 )+(4 +6 )(2 +2 )=4 2 +4 0 =8 2。【输入输出样例2】sum.insum.out15451082229977564242233433244441111388CCF全国信息学奥林匹克联赛(NOIP2 0 1 5)复赛第6页共8页。见选手目录下的sum/sum2 .in和sum/sum2 .ans。【输入输出样例3】见选手目录下的sum/sum3 .in和sum/sum3 .ans。【数据说明】对于第1组至第2组数据,11 0 0 ,15;对于第3组至第4组数据,13 0 0 0 ,11 0 0;对于第5组至第6组数据,
11、11 0 0 0 0 0 ,11 0 0 0 0 0,且不存在出现次数超过2 0的颜色;对于全部1 0组数据,11 0 0 0 0 0 ,11 0 0 0 0 0 ,1攰攰,11 0 0 0 0 0。CCF全国信息学奥林匹克联赛(NOIP2 0 1 5)复赛第7页共8页。4 .推销员(salesman.cpp/c/pas)【问题描述】阿明是一名推销员,他奉命到螺丝街推销他们公司的产品。螺丝街是一条死胡同,出口与入口是同一个,街道的一侧是围墙,另一侧是住户。螺丝街一共有N家住户,第i家住户到入口的距离为Si米。由于同一栋房子里可以有多家住户,所以可能有多家住户与入口的距离相等。阿明会从入口进入,
12、依次向螺丝街的X家住户推销产品,然后再原路走出去。阿明每走1米就会积累1点疲劳值,向第i家住户推销产品会积累Ai点疲劳值。阿明是工作狂,他想知道,对于不同的X,在不走多余的路的前提下,他最多可以积累多少点疲劳值。【输入格式】输入文件名为salesman.in。第一行有一个正整数N,表示螺丝街住户的数量。接下来的一行有N个正整数,其中第i个整数Si表示第i家住户到入口的距离。数据保证S1S2Sn1 0 8。接下来的一行有N个正整数,其中第i个整数Ai表示向第i户住户推销产品会积累的疲劳值。数据保证Ai1 0 3。【输出格式】输出文件名为salesman.out。输出N行,每行一个正整数,第i行整
13、数表示当X=i时,阿明最多积累的疲劳值。【输入输出样例1】salesman.insalesman.out512345123451519222425见选手目录下的salesman/salesman1 .in和salesman/salesman1 .ans。【输入输出样例1说明】X=1 :向住户5推销,往返走路的疲劳值为5 +5,推销的疲劳值为5,总疲劳值为1 5。X=2 :向住户4、5推销,往返走路的疲劳值为5 +5,推销的疲劳值为4 +5,总疲劳值为5 +5 +4 +5 =1 9。X=3 :向住户3、4、5推销,往返走路的疲劳值为5 +5,推销的疲劳值3 +4 +5,总疲劳值为5 +5 +3
14、+4 +5 =2 2。CCF全国信息学奥林匹克联赛(NOIP2 0 1 5)复赛第8页共8页。X=4 :向住户2、3、4、5推销,往返走路的疲劳值为5 +5,推销的疲劳值2 +3 +4 +5,总疲劳值5 +5 +2 +3 +4 +5 =2 4。X=5 :向住户1、2、3、4、5推销,往返走路的疲劳值为5 +5,推销的疲劳值1 +2 +3 +4 +5,总疲劳值5 +5 +1 +2 +3 +4 +5 =2 5。【输入输出样例2】salesman.insalesman.out512245543411217212427见选手目录下的salesman/salesman2 .in和salesman/sal
15、esman2 .ans。【输入输出样例2说明】X=1:向住户4推销,往返走路的疲劳值为4 +4,推销的疲劳值为4,总疲劳值4 +4 +4 =1 2。X=2:向住户1、4推销,往返走路的疲劳值为4 +4,推销的疲劳值为5 +4,总疲劳值4 +4 +5 +4 =1 7。X=3:向住户1、2、4推销,往返走路的疲劳值为4 +4,推销的疲劳值为5 +4 +4,总疲劳值4 +4 +5 +4 +4 =2 1。X=4:向住户1、2、3、4推销,往返走路的疲劳值为4 +4,推销的疲劳值为5 +4 +3 +4,总疲劳值4 +4 +5 +4 +3 +4 =2 4。或者向住户1、2、4、5推销,往返走路的疲劳值为5 +5,推销的疲劳值为5 +4 +4 +1,总疲劳值5 +5 +5 +4 +4 +1 =2 4。X=5:向住户1、2、3、4、5推销,往返走路的疲劳值为5 +5,推销的疲劳值为5 +4 +3 +4 +1,总疲劳值5 +5 +5 +4 +3 +4 +1 =2 7。【样例输入输出3】见选手目录下的salesman/salesman3 .in和salesman/salesman3 .ans。【数据说明】对于2 0 %的数据,1N2 0;对于4 0 %的数据,1N1 0 0;对于6 0 %的数据,1N1 0 0 0;对于1 0 0 %的数据,1N1 0 0 0 0 0。