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

第十七届全国青少年信息学奥林匹克联赛初赛试题普及组C++
第十七届2011全国青少年信息学奥林匹克联赛初赛试题(普及组C++)
第十七届全国青少年信息学奥林匹克联赛初赛试题
(普及组C++语言二小时完成)
●●全部试题答案均要求写在答卷纸上,写在试卷纸上一律无效●●
一、单项选择题(共20题,每题1.5分,共计30分。
每题有且仅有一个正确选项。
)
1.在二进制下,1011001+()=1100110。
A.1011B.1101C.1010D.1111
2.字符“0”的ASCII码为48,则字符“9”的ASCII码为()。
A.39B.57C.120D.视具体的计算机而定
3.一片容量为8GB的SD卡能储存大约()张大小为2MB的数码照片。
A.1600B.2000C.4000D.16000
11.广度优先搜索时,需要用到的数据结构是()。
A.链表B.队列C.栈D.散列表
12.在使用高级语言编写程序时,一般提到的“空间复杂度”中的“空间”是指()。
A.程序运行时理论上所占的内存空间
B.程序运行时理论上所占的数组空间
C.程序运行时理论上所占的硬盘空间
D.程序源文件理论上所占的硬盘空间
13.在含有n个元素的双向链表中查询是否存在关键字为k的元素,最快情况下运行的时间复杂度是()。
A.O
(1)B.O(logn)C.O(n)D.O(nlogn)
14.生物特征识别,是利用人体本身的生物特征进行身份认证的一种技术。
目前,指纹识别、虹膜识别、人脸识别等技术已广泛应用于政府、银行、安全防卫等领域。
一下不属于生物特征识别技术及其应用的是()。
A.指静脉验证B.步态验证C.ATM机密码验证D.声音验证
15.现有一段文言文,要通过二进制哈夫曼编码进行压缩。
简单起见,假设这段文言文只由4个汉字“之”、“呼”、“者”、“也”组成,它们出现的次数分别为700、600、300、200。
那么,“也”字的编码长度是()。
A.1B.2C.3D.4
16.关于汇编语言,下列说法错误的是()
A.是一种与具体硬件相关的程序设计语言
B.在编写复杂程序时,相对于高级语言而言代码量较大,且不易调试
C.可以直接访问寄存器、内存单元、以及I/O端口
D.随着高级语言的诞生,如今已完全被淘汰,不再使用
17.()是一种选优搜索法,按选优条件向前搜索,以达到目标。
当搜索到某一步时,发现原先选择并不优或达不到目标,就退回一步重新选择。
:
A.回溯法B.枚举法C.动态规划D.贪心
18.1956年()手语肖克利、巴丁和布拉顿,以表彰他们对半导体的研究和晶体管效应的发现。
A.诺贝尔物理学奖B.约翰·冯·诺依曼奖C.图灵奖D.高德纳奖
19.对一个有向图而言,如果每个节点都存在到达其他任何节点的路径,那么就称它是强连通的。
例如,有图就是一个强连通图。
事实上,在删掉边()后,它依然是强连通的。
A.aB.bC.cD.d
20.从ENIAC到当前最先进的计算机,冯·诺依曼体系结构始终占有重要地位。
冯诺依曼提醒结构的核心内容是()。
A.采用开关电路B.采用半导体器件
C.采用存储程序和程序控制原理D.采用键盘输入
二.问题求解(共2题,每空5分,共计10分)
1.每份考卷都有一个8位二进制序列号。
当且仅当一个序列号含有偶数个1时,它才是有效的。
例如,0000000、01010011都是有效的序列号,而11111110不是。
那么,有效的序列号共有 个。
2.定义字符串的基本操作为:
删除一个字符\插入一个字符和将一个字符修改成另外一个字符这三种操作。
将字符串A变成字符串B的最少操作步数,称为字符串A到字符串B的编辑距离。
字符串“ABCDEFG”到字符串“BADECG”的编辑距离为。
三.阅读程序写结果(共4题,每题8分,共计32分)
1.
#include
usingnamespacestd;
intmain()
{
inti,n,m,ans;
cin>>n>>m;
i=n;
ans=0;
while(i<=m){
ans+=i;
i++;
}
cout<return0;
}
输入:
1020
输出:
_________
2.
#include
#include
usingnamespacestd;
intmain()
{
stringmap="2223334445556667778889999";
stringtel;
inti;
cin>>tel;
for(i=0;iif((tel[i]>='0')&&(tel[i]<='9'))
cout<elseif((tel[i]>='A')&&(tel[i]<='Z'))
cout<