NOIP2015普及组复赛解题报告.docVIP

  1. 1、本文档共17页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
NOIP2015普及组解题报告 南京师范大学附属中学树人学校 CT 1. 金币(coin.cpp/c/pas) 【问题描述】 国王将金币作为工资,发放给忠诚的骑士。第一天,骑士收到一枚金币;之后两天(第二天和第三天),每天收到两枚金币;之后三天(第四、五、六天),每天收到三枚金币;之后四天(第七、八、九、十天),每天收到四枚金币……;这种工资发放模式会一直这样延续下去:当连续N天每天收到N枚金币后,骑士会在之后的连续N+1天里,每天收到N+1枚金币。 请计算在前K天里,骑士一共获得了多少金币。 【输入格式】 输入文件名为coin.in。 输入文件只有1行,包含一个正整数K,表示发放金币的天数。 【输出格式】 输出文件名为coin.out。 输出文件只有1行,包含一个正整数,即骑士收到的金币数。【数据说明】 对于100%的数据,1 ≤K ≤10,000。 2、扫雷游戏(mine.cpp/c/pas) 【问题描述】 扫雷游戏是一款十分经典的单机小游戏。在n行m列的雷区中有一些格子含有地雷(称之为地雷格),其他格子不含地雷(称之为非地雷格)。玩家翻开一个非地雷格时,该格将会出现一个数字——提示周围格子中有多少个是地雷格。游戏的目标是在不翻出任何地雷格的条件下,找出所有的非地雷格。 现在给出n行m列的雷区中的地雷分布,要求计算出每个非地雷格周围的地雷格数。 注:一个格子的周围格子包括其上、下、左、右、左上、右上、左下、右下八个方向上与之直接相邻的格子。 【输入格式】 输入文件名为mine.in。 输入文件第一行是用一个空格隔开的两个整数n和m,分别表示雷区的行数和列数。 接下来n行,每行m个字符,描述了雷区中的地雷分布情况。字符’*’表示相应格子是地雷格,字符’?’表示相应格子是非地雷格。相邻字符之间无分隔符。 【输出格式】 输出文件名为mine.out。 输出文件包含n行,每行m个字符,描述整个雷区。用’*’表示地雷格,用周围的地雷个数表示非地雷格。相邻字符之间无分隔符。【数据说明】 对于100%的数据,1≤n≤100,1≤m≤100。 3. 求和(sum.cpp/c/pas) 【问题描述】 一条狭长的纸带被均匀划分出了n个格子,格子编号从1到n。每个格子上都染了一种颜色(用[1,m]当中的一个整数表示),并且写了一个数字。定义一种特殊的三元组:(x, y, z),其中x,y,z都代表纸带上格子的编号,这里的三元组要求满足以下两个条件: 1. 都是整数, y z, y ? x = z ? y 2. colorx=colorz 满足上述条件的三元组的分数规定为(x+z)(numberx+numberz)。整个纸带的分数规定为所有满足条件的三元组的分数的和。这个分数可能会很大,你只要输出整个纸带的分数除以10,007所得的余数即可。 【输入格式】 输入文件名为sum.in。 第一行是用一个空格隔开的两个正整数和,代表纸带上格子的个数,代表纸带上颜色的种类数。 第二行有个用空格隔开的正整数,第个数字代表纸带上编号为的格子上面写的数字。 第三行有个用空格隔开的正整数,第个数字代表纸带上编号为的格子染的颜色。 【输出格式】 输出文件名为sum.out。 共一行,一个整数,表示所求的纸带分数除以10,007所得的余数。【数据说明】 对于第1组至第2组数据,1≤≤100,1≤m≤5; 对于第3组至第4组数据,1≤≤3000,1≤m≤100; 对于第5组至第6组数据,1≤≤100000,1≤m≤100000,且不存在出现次数超过20的颜色; 对于全部10组数据,1≤≤ 100000, 1≤ m ≤ 100000, 1 ≤ colori ≤ m, 1 ≤ numberi ≤100000。#include cstdio const int maxn=100000; const int maxm=100000; const int p=10007; int n,m,ans; int number[maxn+1],colour[maxn+1]; int s[2][maxm+1][4]; void init() { freopen(sum.in,r,stdin); freopen(sum.out,w,stdout); scanf(%d%d,n,m); for(int i=1;i=n;i++) scanf(%d,number[i]); for(int i=1;i=n;i++) scanf(%d,colour[i]); } void solve() { for(int i=1;i=n;i++) { int z=i%p,numz=number[i]%p,c=colour[i],t=i%2; int count=

文档评论(0)

2518887 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档