全国青少年信息学奥林匹克联赛初赛试题.docx

上传人:b****4 文档编号:26987160 上传时间:2023-06-24 格式:DOCX 页数:12 大小:21.69KB
下载 相关 举报
全国青少年信息学奥林匹克联赛初赛试题.docx_第1页
第1页 / 共12页
全国青少年信息学奥林匹克联赛初赛试题.docx_第2页
第2页 / 共12页
全国青少年信息学奥林匹克联赛初赛试题.docx_第3页
第3页 / 共12页
全国青少年信息学奥林匹克联赛初赛试题.docx_第4页
第4页 / 共12页
全国青少年信息学奥林匹克联赛初赛试题.docx_第5页
第5页 / 共12页
点击查看更多>>
下载资源
资源描述

全国青少年信息学奥林匹克联赛初赛试题.docx

《全国青少年信息学奥林匹克联赛初赛试题.docx》由会员分享,可在线阅读,更多相关《全国青少年信息学奥林匹克联赛初赛试题.docx(12页珍藏版)》请在冰豆网上搜索。

全国青少年信息学奥林匹克联赛初赛试题.docx

全国青少年信息学奥林匹克联赛初赛试题

第十四届全国青少年信息学奥林匹克联赛初赛试题

(提高组C语言二小时完成)

●●全部试题答案均要求写在答卷纸上,写在试卷纸上一律无效●●

一、单项选择题(共10题,每题1.5分,共计15分。

每题有且仅有一个正确答案)。

1.在以下各项中,()不是操作系统软件。

A.SolarisB.LinuxC.SybaseD.WindowsVistaE.Symbian

2.微型计算机中,控制器的基本功能是()。

A.控制机器各个部件协调工作B.实现算术运算和逻辑运算C.存储各种控制信息

D.获取外部信息E.存放程序和数据

3.设字符串S=”Olympic”,S的非空子串的数目是()。

A.29B.28C.16D.17E.7

4.完全二叉树共有2*N-1个结点,则它的叶节点数是()。

A.N-1B.2*NC.ND.2N-1E.N/2

5.将数组{8,23,4,16,77,-5,53,100}中的元素按从大到小的顺序排列,每次可以交换任意两个元素,最少需要交换()次。

A.4B.5C.6D.7E.8

6.设栈S的初始状态为空,元素a,b,c,d,e,f依次入栈S,出栈的序列为b,d,c,f,e,a,则栈S的容量至少应该是()。

A.6B.5C.4D.3E.2

7.与十进制数28.5625相等的四进制数是()。

A.123.21B.131.22C.130.22D.130.21E.130.20

8.递归过程或函数调用时,处理参数和返回地址,通常使用一种称为()的数据结构。

A.队列B.多维数组C.线性表D.链表E.栈

9.TCP/IP是一组构成互联网基础的网络协议,字面上包括两组协议:

传输控制协议(TCP)和网际协议(IP)。

TCP/IP协议把Internet网络系统描述成具有四个层次功能的网络模型,其中提供源节点和目的节点之间的信息传输服务,包括寻址和路由器选择等功能的是()。

A.链路层B.网络层C.传输层D.应用层E.会话层

10.对有序数组{5,13,19,21,37,56,64,75,88,92,100}进行二分查找,等概率的情况下查找成功的平均查找长度(平均比较次数)是()。

A.35/11B.34/11C.33/11D.32/11E.34/10

二、不定项选择题(共10题,每题1.5分,共计15分。

每题正确答案的个数大于或等于1。

多选或少选均不得分)。

11.在下列关于图灵奖的说法中,正确的有()。

A.图灵奖是美国计算机协会于1966年设立的,专门奖励那些对计算机事业作出重要贡献的个人

B.图灵奖有“计算机界诺贝尔奖”之称

C.迄今为止,还没有华裔计算机科学家获此殊荣

D.图灵奖的名称取自计算机科学的先驱、英国科学家阿兰·图灵

12.计算机在工作过程中,若突然停电,()中的信息不会丢失。

A.硬盘B.CPUC.ROMD.RAM

13.设A=true,B=false,C=true,D=false,以下逻辑运算表达式值为真的有()。

A.(A∧B)∨(C∧D∨

A)B.((

A∧B)∨C)∧

D

C.(B∨C∨D)∨D∧AD.A∧(D∨

C)∧B

14.Web2.0是近年来互联网的热门概念之一,其核心思想是互动与分享。

下列网站中,()是典型的Web2.0应用。

A.SinaB.FlickrC.YahooD.Google

15.(2008)10+(5B)16的结果是()。

A.(833)16B.(2099)10C.(4063)8D.(100001100011)2

16.二叉树T,已知其先根遍历是1243576(数字为结点的编号,以下同),后根遍历是4275631,则该二叉树的可能的中根遍历是()。

A.4217536B.2417536

C.4217563D.2415736

17.面向对象程序设计(Object-OrientedProgramming)是一种程序设计的方法论,它将对象作为程序的基本单元,将数据和程序封装在对象中,以提高软件的重用性、灵活性和扩展性。

下面关于面向对象程序设计的说法中,正确的是()。

A.面向对象程序设计通常采用自顶向下设计方法进行设计。

B.面向对象程序设计方法具有继承性(inheritance)、封装性(encapsulation)、多态性(polymorphism)等几大特点。

C.支持面向对象特性的语言称为面向对象的编程语言,目前较为流行的有C++、JAVA、C#等。

D.面向对象的程序设计的雏形来自于Simula语言,后来在SmallTalk语言的完善和标准化的过程中得到更多的扩展和对以前思想的重新注解。

至今,SmallTalk语言仍然被视为面向对象语言的基础。

18.设T是一棵有n个顶点的树,下列说法正确的是()。

A.T是连通的、无环的B.T是连通的,有n-1条边

C.T是无环的,有n-1条边D.以上都不对

19.NOIP竞赛推荐使用的语言环境有()。

A.Dev-C++B.VisualC++C.freepascalD.Lazarus

20.在下列防火墙(firewall)的说法中,正确的有()。

A.防火墙是一项协助确保信息安全的设备,其会依照特定的规则,允许或是限制数据通过

B.防火墙可能是一台专属的硬件或是安装在一般硬件上的一套软件

C.网络层防火墙可以视为一种IP数据包过滤器,只允许符合特定规则的数据包通过,其余的一概禁止穿越防火墙

D.应用层防火墙是在TCP/IP的“应用层”上工作,可以拦截进出某应用程序的所有数据包

三.问题求解(共2题,每题5分,共计10分)

1.有6个城市,任何两个城市之间都有一条道路连接,6个城市两两之间的距离如下表所示,则城市1到城市6的最短距离为_____________。

城市1

城市2

城市3

城市4

城市5

城市6

城市1

0

2

3

1

12

15

城市2

2

0

2

5

3

12

城市3

3

2

0

3

6

5

城市4

1

5

3

0

7

9

城市5

12

3

6

7

0

2

城市6

15

12

5

9

2

0

2.书架上有21本书,编号从1到21,从其中选4本,其中每两本的编号都不相邻的选法一共有______种。

四.阅读程序写结果(共4题,每题8分,共计32分)

1.#include

intmain()

{

inti,a,b,c,d,f[4];

for(i=0;i<4;i++)

scanf("%d",&f[i]);

a=f[0]+f[1]+f[2]+f[3];

a=a/f[0];

b=f[0]+f[2]+f[3];

b=b/a;

c=(b*f[1]+a)/f[2];

d=f[(b/c)%4];

if(f[(a+b+c+d)%4]>f[2])

printf("%d\n",a+b);

else

printf("%d\n",c+d);

return0;

}

输入:

9192939

输出:

_______________

2.#include

voidfoo(inta,intb,intc)

{

if(a>b)

foo(c,a,b);

else

printf("%d,%d,%d\n",a,b,c);

}

intmain()

{

inta,b,c;

scanf("%d%d%d",&a,&b,&c);

foo(a,b,c);

return0;

}

输入:

213

输出:

__________

3.#include

voidf(inta,intb,intc)

{

printf("%d%d%d/",a,b,c);

if(a==3&&b==2&&c==1)

return;

if(b

f(a,c,b);

elseif(a

{

if(a

f(c,a,b);

else

f(b,c,a);

}

}

intmain()

{

inta,b,c;

scanf("%d%d%d",&a,&b,&c);

f(a,b,c);

printf("\n");

return0;

}

输入:

132

输出:

________________________________________

4.#include

#include

inti,j,len;

chars[50];

intmain()

{

scanf("%s",s);

len=strlen(s);

for(i=0;i

{

if(s[i]>='A'&&s[i]<='Z')s[i]-='A'-'a';

}

for(i=0;i

{

if(s[i]<'x')s[i]+=3;elses[i]+=-23;

}

printf("%s/",s);

for(j=1;j<4;j++)

{

for(i=0;i

{

s[i]=s[i+j];

}

}

printf("%s\n",s);

return0;

}

输入:

ABCDEFGuvwxyz

输出:

___________________________________________

五.完善程序(前6空,每空3分,后5空,每空2分,共28分)

1.(找第k大的数)给定一个长度为1,000,000的无序正整数序列,以及另一个数n(1<=n<=1000000),接下来以类似快速排序的方法找到序列中第n大的数(关于第n大的数:

例如序列{1,2,3,4,5,6}中第3大的数是4)。

#include

#include

inta[1000001],n,ans=-1;

voidswap(int*a,int*b)

{

intc;

c=*a;*a=*b;*b=c;

}

intFindKth(intleft,intright,intn)

{

inttmp,value,i,j;

if(left==right)returnleft;

tmp=rand()%(right-left)+left;

swap(&a[tmp],&a[left]);

value=①

i=left;

j=right;

while(i

{

while(i

if(i

while(i

if(i

}

if(i

if(i>n)return⑥

returni;

}

intmain()

{

inti;

intm=1000000;

for(i=1;i<=m;i++)

scanf("%d",&a[i]);

scanf("%d",&n);

ans=FindKth(1,m,n);

printf("%d\n",a[ans]);

return0;

}

2.(矩阵中的数字)有一个n*n(1<=n<=5000)的矩阵a,对于1<=i

即矩阵中左右相邻的两个元素,右边的元素一定比左边的大。

上下相邻的两个元素,下面的元素一定比上面的大。

给定矩阵a中的一个数字k,找出k所在的行列(注意:

输入数据保证矩阵中的数各不相同)。

#include

intn,k,answerx,answery;

inta[5001][5001];

voidFindKPosition()

{

inti=n,j=n;

while(j>0)

{

if(a[n][j]

j--;

}

while(a[i][j]!

=k)

{

while(②&&i>1)i--;

while(③&&j<=n)j++;

}

}

intmain()

{

inti,j;

scanf("%d",&n);

for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

scanf("%d",&a[i][j]);

scanf("%d",&k);

FindKPosition();

printf("%d%d\n",answerx,answery);

return0;

}

 

答案:

一、单选 

1. C 2. A 3. B 4. C 5. B 

6. D 7. D 8. E 9. B 10. C 

二、多选 

11. ABD 12. AC 13. BC 14. B 15. ABC 

16. ABD 17. BCD 18. ABC 19. ACD 20. ABCD 

三、问题求解 

1.7 人工dijkstra即可 

2.3060 = C(18,4),二十一本书挖掉三个“空格” 

四、阅读理解 

1. 23 (人脑虚拟机即可) 

2. 1,3,2 (简单递归) 

3. 132/213/231/312/321/ (全排列) 

4. defghijxyzabc/hfizxjaybcccc (字符串……还有很WC的ASCII) 

五、完善填空 

(说明:

以下各程序填空可能还有一些等价的写法,各省可请本省专家审定和上机验证,不一定上报科学委员会审查) 

1. 

① a[left] 

② a[j] < value (或a[j] <= value) (不过好像“<=”有影响……) 

③ a[i] > value (或a[i] >= value) 

④ a[i] :

= value; 

⑤ i,right,n 

⑥ FindKth(left, i, n-i+1) 

2. 

① inc(j); (或者j :

= j+1; ) 

② a[i,j] > k 

③ a[i,j] < k 

④ answerx :

= i; 

⑤ answery :

= j;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 求职职场 > 简历

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

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