ImageVerifierCode 换一换
格式:DOCX , 页数:12 ,大小:21.40KB ,
资源ID:22465041      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/22465041.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(noip初赛提高组精彩试题卷和问题详解Word格式文档下载.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

noip初赛提高组精彩试题卷和问题详解Word格式文档下载.docx

1、 (23 or 2 xor 5)的值是( )A. 18 B. 1 C.23 D.32 E.246在 Pascal 语言中,判断整数a 等于 0 或b等于 0或c等于0 的正确的条件表达式是(A. not (a0) or (b0) or (c0) B. not (a0) and (b0) and (cC. not (a=0) and (b=0) or (c=0) D.(a=0) and (b=0) and (c=0) E. not (a=0) or (b=0) or (c=0) 7. 地面上有标号为A、B、C的3根细柱, 在A柱上放有10个直径相同中间有孔的圆盘, 从上到下次依次编号为1, 2,

2、 3, ,将A柱上的部分盘子经过B柱移入C柱, 也可以在B柱上暂存。如果B柱上的操作记录为:“进,进,出,进,进,出,出,进,进,出,进,出,出”。那么, 在C柱上, 从下到上的盘子的编号为(A. 2 4 3 6 5 7 B. 2 4 1 2 5 7 C. 2 4 3 1 7 6 D. 2 4 3 6 7 5 E. 2 1 4 3 7 5 8. 与十进制数17.5625相对应的8进制数是(A. 21.5625 B. 21.44 C. 21.73 D. 21.731 E. 前4个答案都不对 9. 欧拉图G是指可以构成一个闭回路的图,且图G的每一条边恰好在这个闭回路上出现一次(即一笔画成)。在以下

3、各个描述中, 不一定是欧拉图的是:A. 图G中没有度为奇数的顶点 B. 包括欧拉环游的图(欧拉环游是指通过图中每边恰好一次的闭路径) C. 包括欧拉闭迹的图(欧拉迹是指通过途中每边恰好一次的路径) D. 存在一条回路, 通过每个顶点恰好一次E. 本身为闭迹的图10. 一个无法靠自身的控制终止的循环称为“死循环”,例如在C语言程序中,语句“while(1)printf(*);”就是一个死循环,运行它将无休止地打印*号。下面关于死循环的说法中, 只有( )是正确的。A. 不存在一种算法, 对任何一个程序及相应的输入数据, 都可以判断是否会出现死循环, 因而, 任何编译系统都不做死循环检查 B. 有

4、些编译系统可以检测出死循环C. 死循环属于语法错误, 既然编译系统能检查各种语法错误, 当然也能检查出死循环 D. 死循环与多进程中出现的“死锁”差不多,而死锁是可以检测的,因而,死循环也是可以检测的E. 对于死循环,只能等到发生时做现场处理, 没有什么更积极的手段 二、 不定项选择题每题正确答案的个数大于或等于 1。多选或少选均不得分)。11. 设A=B=true,C=D=false,以下逻辑运算表达式值为真的有(A. (AB)(CDA) B. ( ( (AB)C)D)C. A(BCD)D D. (A(DC) B12. 命题“PQ”可读做P蕴含Q, 其中P、Q是两个独立的命题. 只有当命题P

5、成立而命题Q不成立时, 命题PQ的值为false, 其它情况均为true. 与命题等价的逻辑关系式是(A. PQ B. PQ C. (PQ) D. (QP )13. (2070)16+(34)8的结果是( (8332)10 B. (208C)16C. (0)2 (20214)814. 已知7个节点的二叉树的先根遍历是1 2 4 5 6 3 7(数字为结点的编号,以下同), 后根遍历是4 6 5 2 7 3 1, 则该二叉树的可能的中根遍历是( )由X2Studio.Net收集 A. 4 2 6 5 1 7 3 B. 4 2 5 6 1 3 7 C. 4 2 3 1 5 4 7 D. 4 2 5

6、 6 1 7 3 15. 冗余数据是指可以由以他数据导出的数据,例如,数据库中已存放了学生的数学、语文、和英语的三科成绩,如果还存放三科成绩的总分,则总分就可以看做冗余数据。冗余数据往往会造成数据的不一致,例如上面4个数据如果都是输入的,由于操作错误使总分不等于三科成绩之和,就会产生矛盾。下面关于冗余数据的说法中, 正确的是(A. 应该在数据库中消除一切冗余数据B. 与用高级语言编写的数据处理系统相比, 用关系数据库编写的系统更容易消除冗余数据C. 为了提高查询效率, 在数据库中可以适当保留一些冗余数据, 但更新时要做相容性检验D. 做相容性检验会降低效率, 可以不理睬数据库中的冗余数据16.

7、在下列各软件中,属于 NOIP 竞赛(复赛)推荐使用的语言环境有(A. gcc B. g+C. Turbo C D. free pascal17. 以下断电之后将仍能保存数据的有(A. 硬盘 B. ROM C. 显存 D. RAM18. 在下列关于计算机语言的说法中,正确的有(A. 高级语言比汇编语言更高级, 是因为它的程序的运行效率更高B. 随着Pascal、C等高级语言的出现, 机器语言和汇编语言已经退出了历史舞台C. 高级语言程序比汇编语言程序更容易从一种计算机移植到另一种计算机上 D. C是一种面向过程的高级计算机语言19. 在下列关于算法复杂性的说法中, 正确的有(A. 算法的时间复

8、杂度,是指它在某台计算机上具体实现时的运行时间B. 算法的时间复杂度,是指对于该算法的一种或几种主要的运算, 运算的次数与问题的规模之间的函数关系 C. 一个问题如果是NPC类的, 就意味着在解决该问题时, 不存在一个具有多项式时间复杂度的算法. 但这一点还没有得到理论上证实,也没有被否定 D. 一个问题如果是NP类的,与C有相同的结论 由X2Studio.Net收集20. 近20年来, 许多计算机专家都大力推崇递归算法,认为它是解决较复杂问题的强有力的工具. 在下列关于递归的说法中, 正确的是(A. 在1977年前后形成标准的计算机高级语言FORTRAN77禁止在程序使用递归, 原因之一是该

9、方法可能会占用更多的存空间. B. 和非递归算法相比, 解决同一个问题, 递归算法一般运行得更快一些 C. 对于较复杂的问题, 用递归方式编程往往比非递归方式更容易一些D. 对于已定义好的标准数学函数sin(x), 应用程序中的语句“y=sin(sin(x);”就是一种递归调用 三问题求解(共 2 题,每题 5 分,共计 10 分)1给定n个有标号的球,标号依次为1,2,n。将这n个球放入r个相同的盒子里,不允许有空盒,其不同放置方法的总数记为S(n,r)。例如,S(4,2)=7,这7种不同的放置方法依次为(1) , (234) , (2) , (134) , (3) , (124) , (4

10、) , (123) , (12) , (34) , (13) , (24) , (14) , (23)。当n=7,r=4时,S(7,4)=。2N个人在操场里围成一圈,将这N个人按顺时针方向从1到N编号,然后从第一个人起,每隔一个人让下一个人离开操场,显然,第一轮过后,具有偶数编号的人都离开了操场。依次做下去,直到操场只剩下一个人,记这个人的编号为J(N),例如,J(5)=3,J(10)=5,等等。则J(400)= (提示:对N=2m+r进行分析,其中0r 10) Then=y+(q1*100-q3) div (pp4 mod 3*5) Else=y+20+(q2*100-q3) div (pp

11、4 mod 3*5); writeln(x,y); end.输入:6 6 5 5 3输出:2. program s402; var a,b: x,y:integer; procedure fun(a,b:integer); var k: k:=a; a:=b; b:=k; end;=3;=6; fun(x,y); write(No.1:,a,b, ); fun(a,b); writeln(No.2:,b);输出:3. program S403; var a1:array1.50 of integer; var i,j,t,t2,n,n2: n:=50;=1 to n do a1:=0; n2:

12、=round(sqrt(n);=2 to n2 do If (a1 = 0) Then t2:=n div i; for j:=2 to t2 do a1i*j:=1; t:=2 to n do write(i:4); inc(t); if(t mod 10=0) then writeln; writeln;4. program S404;const n=12; ch2:array0.12 of char =(qASORTEXMPLvar k: ch:array0.12 of char;procedure shift(k,n:var v:char; j:begin v:=chk;=k+k; w

13、hile (j=n) do if (jn) and (ord(chj)ord(chj+1) then inc(j); if (ord(v)ord(chj) then begin chj div 2:=chj;=j*2; end else exit; chj div 2:=v;end;procedure hpsrt; tmp: for k:=n div 2 downto 1 do shift(k,n);=1 to n do write(chk);=n downto 1 do=ch1; ch1: chk:=tmp; shift(1,k-1);=0 to n do chk:=ch2k; hpsrt;

14、=1 to n do write(chk);end.五完善程序 (前 5 空,每空 2 分,后 6 空,每空 3 分,共 28 分)1(格雷码 Gray Code) 由X2Studio.Net收集Gray Code是一种二进制编码,编码顺序与相应的十进制数的大小不一致。其特点是,对于两个相邻的十进制数,对应的两个格雷码只有一个二进制位不同。另外,最大数与最小数间也仅有一个二进制位不同,以4位二进制数为例,编码如下:十进制数 格雷码 十进制数 格雷码 0 0000 8 1100 1 0001 9 1101 2 0011 10 1111 3 0010 11 1110 4 0110 12 1010

15、5 0111 13 1011 6 0101 14 1001 7 0100 15 1000由X2Studio.Net收集如果把每个二进制的位看做一个开关,则将一个数变为相邻的另一个数,只须改动一个开关。因此,格雷码广泛用于信号处理、数-模转换等领域。下面程序的任务是:由键盘输入二进制的位数n(n16),再输入一个十进制数m(0m2n),然后输出对应于m的格雷码(共n位,用数组gr 存放) program s501; var bound,m,n,i,j,b,p: gr:array0.14of integer; begin bound:writeln(input n,mreadln(n,m);for

16、 i:=1 to n do bound:= ;if (m=bound) then begin Data error! b:=1 to n do p:=b*2;for to m do if ( ) then =1-p;gr:=p;=n do write(gr);writeln;2(连续邮资问题)某国发行了n种不同面值的邮票,并规定每封信上最多允许贴m邮票。在这些约束下,为了能贴出1,2,3,maxvalue连续整数集合的所有邮资,并使maxvalue的值最大,应该如何设计各邮票的面值?例如,当n=5和m=4时,面值设计为(1,3,11,15,32),可使maxvalue达到最大值70(或者说,用

17、这些面值的1至4邮票可以表示不超过70的所有邮资,但无法表示邮资71)。而用其他面值的1至4邮票如果可以表示不超过k的所有邮资,必有k70)由X2Studio.Net收集下面是用递归回溯求解连续邮资问题的程序。数组x1:n表示n种不同的邮票面值,并约定各元素按下标是严格递增的。数组bestx1:n存放使maxvalue达到最大值的邮票面值(最优解),数组ymaxl用于记录当前已选定的邮票面值x1:i能贴出的各种邮资所需的最少邮票数。请将程序补充完整。program S502;const NN=20; maxint=30000; maxl=500;var bestx,x:array 0.NN o

18、f integer;array 0.maxl of integer; j,n,m,maxvalue:procedure result;var j:max=,maxvalue);for j: write(bestxj:procedure backtrace(i,r:var j,k: z: array0.maxl of integer;=0 to do if (yjm) then=1 to m-yj do if (yj+k=y ) then y :=yj+k; while (yrn) then if (r-1maxvalue) then maxvalue: ;=1 to n do bestxj:=xj;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1