NOIP2011普及组初赛试题及答案C++版.docx
NOIP2011普及组初赛试题及答案C+版第十七届全国青少年信息学奥林匹克联赛初赛试题普及组C+语言二小时完成全部试题答案均要求写在答卷纸上,写在试卷纸上一律无效一、单项选择题共20题,每题1.5分,共计30分。每题有且仅有一个正确选项。1在二进制下,1011001+=1100110。A1011B1101C1010D11112字符“0的ASCII码为48,则字符“9的ASCII码为。A39B57C120D视详细的计算机而定3一片容量为8G的SD卡能储存大约张大小为2MB的数码照片。A1600B2000C4000D160004摩尔定律Moore'slaw)是由英特尔创始人之一戈登·摩尔(GordonMoor)提出来的。根据摩尔定律,在过去几十年一级在可预测的将来纪念,单块集成电驴的集成度大约每个月翻一番。A1B6C18D365无向完全图是图中每对顶点之间都恰好有一条边的简单图。已知无向完全图G有7个顶点,则它共有条边。A7B21C42D496寄存器是的重要组成部分。A硬盘B高速缓存C内存D中央处理器CPU7假如根结点的深度记为1,则一棵恰有2020个叶结点的二叉树的深度最少是。A10B11C12D138体育课的铃声响了,同学们都陆续地奔向操场,按教师的要求从高到矮站成一排。每个同学按顺序来到操场时,都从排尾走到排头,找到第一个比本人高的同学,并站在他的后面。这种站队的方法类似于算法。A快速排序B插入排序C冒泡排序D归并排序9一个正整数在二进制下有100位,则它在十六进制下有位。A7B13C25D不能确定10有人以为,在个人电脑送修前,将文件放入回收站中就是已经将其删除了。这种想法是。A正确的,将文件放入回收站以为着彻底删除、无法恢复B不正确的,只要将回收站清空后,才意味着彻底删除、无法恢复C不正确的,即便回收站清空,文件只是被标记为删除,仍可能通过回复软件找回D不正确的,只要在硬盘上出现过的文件,永远不可能被彻底删除11广度优先搜索时,需要用到的数据构造是。A链表B队列C栈D散列表12在使用高级语言编写程序时,一般提到的“空间复杂度中的“空间是指。A程序运行时理论上所占的内存空间B程序运行时理论上所占的数组空间C程序运行时理论上所占的硬盘空间D程序源文件理论上所占的硬盘空间13在含有n个元素的双向链表中查询能否存在关键字为k的元素,最快情况下运行的时间复杂度是。AO(1)BO(logn)CO(n)DO(nlogn)14生物特征识别,是利用人体本身的生物特征进行身份认证的一种技术。目前,指纹识别、虹膜识别、人脸识别等技术已广泛应用于政府、银行、安全防卫等领域。一下不属于生物特征识别技术及其应用的是。A指静脉验证B步态验证CATM机密码验证D声音验证15现有一段文言文,要通过二进制哈夫曼编码进行压缩。简单起见,假设这段文言文只由4个汉字“之、“呼、“者、“也组成,它们出现的次数分别为700、600、300、200。那么,“也字的编码长度是。A1B2C3D416关于汇编语言,下列讲法错误的是A是一种与详细硬件相关的程序设计语言B在编写复杂程序时,相对于高级语言而言代码量较大,且不易调试C能够直接反问寄存器、内存单元、以及I/O端口D随着高级语言的诞生,如今已完全被淘汰,不再使用17是一种选优搜索法,按选优条件向前搜索,以到达目的。当搜索到某一步时,发现原先选择并不优或达不到目的,就退回一步重新选择。:A回溯法B枚举法C动态规划D贪心181956年手语肖克利、巴丁和布拉顿,以表彰他们对半导体的研究和晶体管效应的发现。A诺贝尔物理学奖B约翰·冯·诺依曼奖C图灵奖D高德纳奖19对一个有向图而言,假如每个节点都存在到达其他任何节点的途径,那么就称它是强连通的。例如,有图就是一个强连通图。事实上,在删掉边后,它仍然是强连通的。AaBbCcDd20从ENIAC到当前最先进的计算机,冯·诺依曼体系构造始终占有重要地位。冯诺依曼提醒构造的核心内容是。A采用开关电路B采用半导体器件C采用存储程序和程序控制原理D采用键盘输入二问题求解共2题,每空5分,共计10分1每份考卷都有一个8位二进制序列号。当且仅当一个序列号含有偶数个1时,它才是有效的。例如,0000000、01010011都是有效的序列号,而11111110不是。那么,有效的序列号共有个。2定义字符串的基本操作为:删除一个字符插入一个字符和将一个字符修改成另外一个字符这三种操作。将字符串变成字符串的最少操作步数,称为字符串到字符串的编辑距离。字符串“ABCDEFG到字符串“BADECG的编辑距离为。三阅读程序写结果共4题,每题8分,共计32分1#includeusingnamespacestd;intmain()inti,n,m,ans;cin>>n>>m;i=n;ans=0;while(i#includeusingnamespacestd;intmain()stringmap="2223334445556667778889999"stringtel;inti;cin>>tel;for(i=0;i='0')&&(teli='A')&&(teli#includeusingnamespacestd;constintSIZE=100;intmain()intn,i,sum,x,aSIZE;cin>>n;memset(a,0,sizeof(a);for(i=1;i>x;ax+;i=0;sum=0;while(sumusingnamespacestd;intsolve(intn,intm)inti,sum;if(m=1)return1;sum=0;for(i=1;i>n>>m;coutusingnamespacestd;constintSIZE=50;intn1,m1,n2,m2,aSIZESIZE,bSIZESIZE;intmain()inti,j,k1,k2;boolgood,haveAns;cin>>n1>>m1;for(i=1;i>aij;cin>>n2>>m2;for(i=1;i#includeusingnamespacestd;constintSIZE=200;structhugeintintlen,numSIZE;/其中len表示大整数的位数;num1表示个位,num2表示十位,以此类推hugeinttimes(hugeinta,hugeintb)/计算大整数a和b的乘积inti,j;hugeintans;memset(ans.num,0,sizeof(ans.num);for(i=1;i0)ans.len=a.len+b.len;elseans.len=a.len+b.len-1;returnans;hugeintadd(hugeinta,hugeintb)/计算大整数a和b的和inti;hugeintans;memset(ans.num,0,sizeof(ans.num);if(a.len>b.len)ans.len=a.len;elseans.len=b.len;for(i=1;i0)ans.len+;returnans;hugeintaverage(hugeinta,hugeintb)/计算大整数a和b的平均数的整数部分inti;hugeintans;ans=add(a,b);for(i=ans.len;i>=2;i-)ans.numi-1+=()*10;ans.numi/=2;ans.num1/=2;if(ans.numans.len=0)ans.len-;returnans;hugeintplustwo(hugeinta)/计算大整数a加2之后的结果inti;hugeintans;ans=a;ans.num1+=2;i=1;while(i=10)ans.numi+1+=ans.numi/10;ans.numi%=10;i+;if(ans.numans.len+1>0);returnans;boolover(hugeinta,hugeintb)/若大整数a>b则返回true,否则返回falseinti;if()returnfalse;if(a.len>b.len)returntrue;for(i=a.len;i>=1;i-)if(a.numib.numi)returntrue;returnfalse;intmain()strings;inti;hugeinttarget,left,middle,right;cin>>s;memset(target.num,0,sizeof(target.num);target.len=s.length();for(i=1;i=1;i-)cout>bijm1-m2+1good=truem2haveAns=true2.ans.numi+j-1ans.numi%=10a.numi+b.numians.numi%2ans.len+a.len