全国信息学(计算机)奥林匹克联赛(NOIP2014)复赛 普及组答案及解析.pdfVIP

全国信息学(计算机)奥林匹克联赛(NOIP2014)复赛 普及组答案及解析.pdf

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

一、实操题

1、珠心算测验

【问题描述】

珠心算是一种通过在脑中模拟算盘变化来完成快速运算的一种计算技术。珠心算训

练,既能够开发智力,又能够为日常生活带来很多便利,因而在很多学校得到普及

某学校的珠心算老师采用一种快速考察珠心算加法能力的测验方法。他随机生成一

个正整数集合,集合中的数各不相同,然后要求学生回答:其中有多少个数,恰好

等于集合中另外两个(不同的)数之和?

最近老师出了一些测验题,请你帮忙求出答案。

【输入】

输入文件名为count.in。

输入共两行,第一行包含一个整数n,表示测试题中给出的正整数个数。

第二行有n

个正整数,每两个正整数之间用一个空格隔开,表示测试题中给出的正整数。

【输出】

输出文件名为count.out。

输出共一行,包含一个整数,表示测验题答案。

【输入输出样例】

【样例说明】

由1+2=3,1+3=4,故满足测试要求的答案为

2。注意,加数和被加数必须是集合中的两个不同的数。

【数据说明】

对于100%的数据,3≤n≤100,测验题给出的正整数大小不超过10,000。

参考答案:```bash#include#include#includeusingnamespacestd;intmain()intn;cin

n;vectornums(n);for(inti=0;in;i++){cinnums[i];}unordered_mapmp;int

ans=0;for(inti=0;in;i++){for(intj=i+1;jn;j++){intsum=nums[i]+

nums[j];if(mp.count(sum)){ans++;}}}coutansendl;return0;```

解析:【喵呜刷题小喵解析】:

本题目要求计算在一个正整数集合中,有多少个数等于集合中另外两个(不同的)

数之和。可以使用两层循环遍历集合中的数,然后计算两个数的和,查看和是否存

在于集合中。如果存在,则答案加一。

具体实现时,可以使用一个哈希表(unordered_map)来存储集合中的数,以便快

速查找。对于每个数,遍历集合中除了它之外的所有数,计算它们的和,并在哈希

表中查找该和是否存在。如果存在,则将答案加一。最终输出答案即可。

上述程序使用C++

实现,包括读入数据、遍历集合、计算答案和输出结果等步骤。程序的时间复杂度

为O(n^2),其中n

是集合中数的个数。由于题目中给出的数据范围较小,因此程序可以在较短时间内

完成计算。

2、比例简化

【问题描述】

在社交媒体上,经常会看到针对某一个观点同意与否的民意调查以及结果。例如,

对某一观点表示支持的有1498人,反对的有902

人,那么赞同与反对的比例可以简单的记为1498:902。

不过,如果把调查结果就以这种方式呈现出来,大多数人肯定不会满意。因为这个

比例的数值太大,难以一眼看出它们的关系。对于上面这个例子,如果把比例记为

5:3,虽然与真实结果有一定的误差,但依然能够较为准确地反映调查结果,同时

也显得比较直观。

现给出支持人数A,反对人数B,以及一个上限L,请你将A比B化简为A’比

B’,要求在A’和B’均不大于L且A’和B’互质(两个整数的最大公约数是

1)的前下,A’/B’≥A/B且A’/B’-A/B的值尽可能小。

【输入】

输入文件名为ratio.in。

输入共一行,包含三个整数

A,B,L,每两个整数之间用一个空格隔开,分别表示支持人数、反对人数以及上

限。

【输出】

输出文件名为ratio.out。

输出共一行,包含两个整数A’,B’,中间用一个空格隔开,表示化简后的比例。

【输入输出样例】

【数据说明】

对于100%的数据,1≤A≤1,000,000,1≤B≤1,000,000,1≤L≤100,A/B≤L。

参考答案:```13```

解析:【喵呜刷题小喵解析】:

首先,我们需要理解题目的要求。题目要求我们将支持人数A和反对人数B

的比例A/B化简为A/B,其中A和B需要满足以下条件:

1.A和B均不大于L。

2.A和B互质(即它们的最大公约数为1)。

3.A/B≥A/B且A/B

文档评论(0)

喵呜刷题 + 关注
实名认证
文档贡献者

来喵呜刷题,完成你的职业蜕变!

1亿VIP精品文档

相关文档