下半年程序员考试真题及答案下午卷.docx

上传人:b****5 文档编号:4279152 上传时间:2022-11-28 格式:DOCX 页数:16 大小:796.02KB
下载 相关 举报
下半年程序员考试真题及答案下午卷.docx_第1页
第1页 / 共16页
下半年程序员考试真题及答案下午卷.docx_第2页
第2页 / 共16页
下半年程序员考试真题及答案下午卷.docx_第3页
第3页 / 共16页
下半年程序员考试真题及答案下午卷.docx_第4页
第4页 / 共16页
下半年程序员考试真题及答案下午卷.docx_第5页
第5页 / 共16页
点击查看更多>>
下载资源
资源描述

下半年程序员考试真题及答案下午卷.docx

《下半年程序员考试真题及答案下午卷.docx》由会员分享,可在线阅读,更多相关《下半年程序员考试真题及答案下午卷.docx(16页珍藏版)》请在冰豆网上搜索。

下半年程序员考试真题及答案下午卷.docx

下半年程序员考试真题及答案下午卷

2013下半年程序员考试真题及答案-下午卷

试题一

【说明】

两个包含有限个元素的非空集合A、B的相似度定义为|A∩B|/|A∪B|,即它们的交集大小(元素个数)与并集大小之比。

以下的流程图计算两个非空整数集合(以数组表示)的交集和并集,并计算其相似度。

已知整数组A[1:

m]和B[1:

n]分别存储了集合A和B的元素(每个集合中包含的元素各不相同),其交集存放于数组C[1:

s],并集存放于数组D[1:

t],集合A和B的相似度存放于SIM。

例如,假设A={1,2,3,4},B={1,4,5,6},则C={1,4},D={1,2,3,4,5,6},A与B的相似度SIM=1/3。

阅读以上说明和流程图,填补流程图中的空缺

(1)〜(5),将解答填入答题纸的对应栏内。

答案解析:

(1)s

(2)t(3)C[s](4)D[t](5)s/t

本题考査程序处理流程图的设计能力。

首先我们来理解两个有限集合的相似度的含义。

两个包含有限个元素的非空集合A、B的相似度定义为它们的交集大小(元素个数)与并集大小之比。

如果两集合完全相等,则相似度必然为1(100%);如果两集合完全不同(没有公共元素),则相似度必然为0;如果集合A中有一半元素就是集合B的全部元素,而另一半元素不属于集合B,则这两个集合的相似度为0.5(50%)。

因此,这个定义符合人们的常理性认识。

在大数据应用中,经常要将很多有限集进行分类。

例如,每天都有大量的新闻稿。

为了方便用户检索,需要将新闻稿分类。

用什么标准来分类呢?

每一篇新闻稿可以用其中所有的关键词来表征。

这些关键词的集合称为这篇新闻稿的特征向量。

两篇新闻稿是否属于同一类,依赖于它们的关键词集合是否具有较高的相似度(公共关键词个数除以总关键词个数)。

搜索引擎可以将相似度超过一定水平的新闻稿作为同一类。

从而,可以将每天的新闻稿进行分类,就可以按用户的需要将某些类的新闻稿推送给相关的用户。

本题中的集合用整数组表示,因此,需要规定同一数组中的元素各不相同(集合中的元素是各不相同的)。

题中,整数组A[1:

m]和B[1:

n]分别存储了集合A和B的元素。

流程图的目标是将A、B中相同的元素存放入数组C[1:

s](共s个元素),并将A、B中的所有元素(相同元素只取一次)存放入数组D[1:

t](共t个元素),最后再计算集合A和B相似度s/t。

流程图中的第一步显然是将数组A中的全部元素放入数组D中。

随后,只需要对数组B中的每个元素进行判断,凡与数组A中某个元素相同时,就将其存入数组C;否则就续存入数组D(注意,数组D中已有m个元素)。

这需要对j(遍历数组B)与i(遍历数组A)进行两重循环。

判断框B[j]=A[i]成立时,B[j]应存入数组C;否则应继续i循环,直到循环结束仍没有相等情况出现时,就应将B[j]存入数组D。

存入数组C之前,需要将其下标s增1;存入数组D之前,需要将其下标t增1。

因此,初始时,应当给j赋0,使数组C的存数从C[l]开始。

从而,

(1)处应填s,(3)处应填C[s]。

而数组D是在已有m个元素后续存,所以,初始时,数组D的下标t应当是m,续存是从D[m+1]幵始的。

因此,

(2)处应填t,(4)处应填D[t]。

两重循环结束后,就要计算相似度s/t,将其赋予SIM,因此(5)处应填s/t。

 

试题二

【说明】

下面的函数sort(intn,inta[])对保存在数组a中的整数序列进行非递减排序。

由于该序列中的元素在一定范围内重复取值,因此排序方法是先计算出每个元素出现的次数并记录在数组b中,再从小到大顺序地排列各元素即可得到一个非递减有序序列。

例如,对于序列6,5,6,9,6,4,8,6,5,其元素在整数区间[4,9]内取值,因此使数组元素b[0]〜b[5]的下标0〜5分别对应数值4〜9,顺序地扫描序列的每一个元素并累计其出现的次数,即将4的个数记入b[0],5的个数记入b[1],依此类推,9的个数记入b[5]。

最后依次判断数组b的每个元素值,并将相应个数的数值顺序地写入结果序列即可。

对于上例,所得数组b的各个元素值如下:

那么在输出序列中写入1个4、2个5、4个6、1个8、1个9,即得4,5,5,6,6,6,6,8,9,从而完成排序处理。

【C函数】

阅读以上说明和C函数,填充函数中的空缺,将解答填入答题纸的对应栏内。

答案解析:

(1)afi]

(2)a[i]>maximum,或a[i]>=maximum,或其等价形式

(3)0

(4)b[k],或b[k]>0,或b[k]!

=0,或其等价形式

(5)k

本题考查C程序的基本语法和运算逻辑。

首先应认真分析题目中的说明,然后确定代码结构和各变量的作用。

(1)和

(2)所在for语句的功能是求出数组a中的最小元素minimum和最大元素maximum。

在设置了minimum和maximum的初始值后,空

(1)处的判断条件是只要目前的元素a[i]小于minimum,就需要更新minimum,反之,空

(2)处的判断条件是只要目前的元素a[i]大于maximum,就需要更新maximum,因此空

(1)处应填入a[i]

(2)处应填入a[i]>maximum或其等价方式。

minimum和maximum的作用是要确定计数数组b的大小。

根据题目中的描述,序列中的每个元素a[i]都对应到计数数组b[]的一个元素b[k],对应方式为:

k=a[i]-minimum,其中minimum是数组a中的最小元素,显然在计数时,一个数值出现一次,就在对应的b[k]中累加一次。

空(3)〜(5)所在的语句组是产生排序后的序列,重新写入数组a。

首先需明确变量i和k的作用,根据它们在该语句组中的出现位置,i用于表示数组a的元素下标,k用于表示数组b中元素的下标,因此,空(3)处应填入0,使得从数组a中下标为0的数组元素开始。

通过循环控制“for(k=0;k0”或其等价形式。

由于b[k]中记录的是元素k+minimum的出现次数,所以空(5)处应填入"k",从而将元素值恢复后再写回去。

 

试题三

【说明1】

F面的函数countChar(char*text)统计字符串text中不同的英文字母数和每个英文字母出现的次数(英文字母不区分大小写)。

【C代码1】

【说明2】

将下面C代码2中的空缺补全后运行,使其产生以下输出。

f2:

f2:

f2:

2

f3:

f3:

1

【C代码2】

阅读以上说明和C代码,填充代码中的空缺,将解答填入答题纸的对应栏内。

答案解析:

(1)text,或&text[0],或其等价形式

(2)ptr++,或++ptr,或ptr=ptr+l,或ptr+=l

(3)c[i],或*(c+i)

(4)f2

(5)f3

(6)f(n),或(*f)(n)

本题考查数据指针、运算逻辑和函数指针的应用。

首先应认真分析题目中的说明,然后确定代码结构和各变量的作用。

在函数countChar(char*text)中来统计字符串text中不同的英文字母数和每个英文字母出现的次数。

用来表示计数值的数组元素c[i]需要与英文字母对应起来,方式为c[0]记录字母A或a的次数,c[l]记录字母B或b的次数,依此类推,因此i=英文字母-‘A’(英文字母为大写)或i=英文字母-‘a’(英文字母为小写)。

数据指针是指向数据的指针变量。

数据指针ptr用来表示text中的每一个字符,初始时ptr指向第一个字符,因此空

(1)处应填入“text”或其等价方式,

(2)处的作用是随循环控制逐个指出text中的后续字符,因此空

(2)处应填入“ptr++”或其等价方式。

显然,若c[i]的值不为0则表示字符‘A’+i或‘a’+i出现了,反之,则表示字符‘A’+i或‘a’+i未出现,因此在计算字符种类时只要判断c[i]是否为0即可,因此空(3)处应填入“c[i]”或其等价形式。

函数指针是指向函数的指针变量。

根据代码2的声明“intfl(int(*f)(int));w可知调用函数fl时,实参应该是函数名或函数指针,且函数名或函数指针指向的函数应有一个整型参数,返回值为整型,而f2和fi都是符合这种定义类型的函数。

C代码2中,在main函数中两次调用了函数fl,分析运行结果可知,是先以f2为实参调用fl,然后以fi为实参调用fl,因此空(4)和(5)分别填入“f2”或“f3”或它们的等价形式,在空(6)处应填入“f(n)”或其等价形式来实现最后对f2和f3的调用。

试题四

【说明】

正整数n若是其平方数的尾部,则称n为同构数。

例如,6是其平方数36的尾部,76是其平方数5776的尾部,6与76都是同构数。

下面的程序求解不超过10000的所有同构数。

已知一位的同构数有三个:

1,5,6,因此二位同构数的个位数字只可能是1,5,6这三个数字。

依此类推,更高位数同构数的个位数字也只可能是1,5,6这三个数字。

下面程序的处理思路是:

对不超过10000的每一个整数a,判断其个位数字,若为1、5或6,则将a转换为字符串as,然后对a进行平方运算,并截取其尾部与as长度相等的若干字符形成字符串后与as比较,根据它们相等与否来断定a是否为同构数。

【C程序】

阅读以上说明和C程序,填充程序中的空缺,将解答填入答题纸的对应栏内。

答案解析:

(1)a%10,或其等价形式

(2)right(rs,len)

(3)num%10,或其等价形式

(4)ch=s[i],或ch=*(s+i)

(5)i++,ms--,或ms--,i++,或其等价形式

本题考查C语言语法、数据指针和运算逻辑的应用。

首先应认真分析题目中的说明,然后确定代码结构和各变量的作用。

根据题目中的叙述,同构数的个位数为1、5或6,因此,对于不超过10000的每个整数,应先获取其个位数字,因此空

(1)处应填入“a%10”或其等价形式,从而可以先过滤掉不可能是同构数的数。

根据代码中的注释,通过以下运算后,得到由a中数值转换所得的字符串as,以及a的平方所得数值转换得到的字符串rs,此后通过字符串比较运算来判断是否为同构数。

函数myitoa(intnum,char*s)的功能是将整数num转换为字符串s,这就需要将整数num的每个数字分离出来,通常通过整除取余运算实现,即以下代码所实现的。

其中,空(3)处应填入“num%10”或其等价形式。

函数right(char*ms,intlength)取字符串ms尾部长度为length的子串,返回所得子串的首字符指针。

该函数的处理思路是先找到ms中字符串的结尾,然后倒着数出length个字符,从而得到所需字符串的首字符指针。

空(5)处应填入“i++,ms--”或其等价形式。

另一个更简便的方式是在得到ms的结尾指针后,再减去length即可,即最后返回ms-length即可。

试题五

【说明】

某应急交通控制系统(TraficControlSystem)在红灯时控制各类车辆(Vehicle)的通行,其类图如图5-1所示,在紧急状态下应急车辆红灯时也可通行,其余车辆按正常规则通行。

下面的C++代码实现以上设计,请完善其中的空缺。

阅读以下说明和C++代码,填充代码中的空缺,将解答填入答题纸的对应栏内。

答案解析:

(1)virtualboolisEmergent()

(2)virtualvoidrunRedLight()

(3)publicCar,publicEmergency

(4)this->isEmergency

(5)ev

(6)v[i]

本题考查C++语言程序设计的能力,涉及类、对象、函数的定义和相关操作。

要求考生根据给出的案例和执行过程说明,认真阅读理清程序思路,然后完成题目。

根据题目描述,以交通控制系统(TraficControlSystem)为背景,本题目中涉及的各类车辆和是否应急状态下在红灯时的通行情况。

根据说明进行设计,题目给出了类图(图5-1类图所示)。

图中父类Vehicle代表交通工具,设计为抽象类,包含一个方法:

run(),表示行驶某一个具体的交通工具对象,行驶的方法由具体子类型完成,所以Vehicle的run()为一个纯虚函数:

Car和Truck都继承自Vehicle的两个子类型,所以它们都继承了Vehicle的run()方法,各自行驶方式有所不同,所以都覆盖了Vehicle的run()方法,并加以实现:

Car的两个子类型PoliceCar和Ambulance都继承自Car,从而PoliceCar和Ambulance也都继承了Car中的run()方法。

Truck的子类FireEngine也继承了Truck中的run()方法。

图中接口Emergency在C++中釆用抽象基类的方法实现,其中约定红灯时通行的相关接口函数为:

isEmergent()和runRedLight(),均为纯虚函数,原型中=0表示纯虚函数,实现由子类完成:

isEmergentO函数接口约定应急车辆返回自身紧急情况状态,用bod类型的isEmergency表示:

this->isEmergency,其值在紧急情况下为bool值true,非紧急情况下为bool值false。

mnRedLight()函数接口约定应急车辆在红灯时如何通行(isEmergency为true,则通行,isEmergency为false,和普通车辆一样通行)。

Emergency的子类有PoliceCar、Ambulance和FireEngine,所以在这三个类中都要实现Emergency中定义的纯虚函数接口。

交通控制类TraficControlSystem对运行的交通工具进行控制,所有交通工具用Vehicle数组v表示;numVehicles表示交通工具数量;control函数进行控制在紧急情况下应急车辆红灯通行,其他情况按常规通行;add()表示有车辆加入系统,shutDown()在系统关闭时清除每个对象数组元素:

deletev[i];。

Vehicle的子类具体类型有Car、Truck、PoliceCar、Ambulance和FireEngine,所以v[]数组中对象有这些类型的对象,加入v[]时会自动向上转型成为Vehicle类型,而实现了Emergency接口的应急车辆有runRedLight()函数,其他Car和Truck只有run()函数。

因此,用for循环对每个v[i],判定是否是Emergency类型,即是否继承了Emergency,调用时动态绑定每个数组元素的实际类型,需要通过动态类型转换:

如果转换成功,说明是Emergency的子类,实现了runRedLight(),可以调用runRedLight(),否则调用run():

主控逻辑代码在main函数中实现。

初始化TraficControlSystem,用tcs表示,调用tcs的add()函数添加具体的交通工具,这里会自动向上转型成为Vehicle类型,调用control()对各车辆进行控制,调用shutDown()系统关闭,使用完数组对象之后,需要用delete操作进行释放对象,即deletetcs;

因此,空

(1)和空

(2)需要定义纯虚函数isEmergent()和runRedLight(),原型中=0题目代码中己经给出,所以空

(1)和空

(2)分别为“virtualboolisEmergent()”和“virtualvoidrunRedLight()”;空(3)需要继承Car和Emergency,即“publicCar,publicEmergency”;空(4)要返回应急车辆对象的状态,即“this->isEmergency”;空(5)处动态类型转换成功的对象ev;空(6)处为普通车辆对象v[i]。

 

试题六

【说明】

某应急交通控制系统(TraficControlSystem)在红灯时控制各类车辆(Vehicle)的通行,其类图如图6-1所示,在紧急状态下应急车辆在红灯时可通行,其余车辆按正常规则通行。

下面的Java代码实现以上设计,请完善其中的空缺。

【Java代码】

阅读以上说明和Java代码,填充程序中的空缺,将解答填入答题纸的对应栏内。

答案解析:

(1)booleanisEmergent()

(2)voidrunRedLight()

(3)extendsCarimplementsEmergency

(4)this.isEmergency

(5)(Emergency)v[i]

(6)v[i]

本题考査Java语言程序设计的能力,涉及类、对象、方法的定义和相关操作。

要求考生根据给出的案例和执行过程说明,认真阅读理清程序思路,然后完成题目。

根据题目说明,以交通控制系统(TraficControlSystem)为背景,本题目中涉及的各类车辆和是否应急状态下在红灯时的通行情况。

根据说明进行设计,题目给出了类图(图6-1类图所示)。

图中父类Vehicle,代表交通工具,设计为抽象类。

在Java用abstract关键字表示,表示行驶某一个具体的交通工具。

Vehicle包含一个抽象方法:

mn(),方法后没有实现,直接用;来表示抽象方法,表示行驶的方法由具体子类型完成,所以Vehicle的mn()为一个抽象方法:

Car和Truck都继承自Vehicle的两个子类型,所以他们都继承了Vehicle的run()方法,各自行驶方式有所不同,所以都覆盖了Vehicle的run()方法,并加以实现:

Car的两个子类型PoliceCar和Ambulance都继承自Car,从而PoliceCar和Ambulance也都继承了Car中的run()方法。

Truck的子类FireEngine也继承了Truck的run()方法。

图6-1中Emergency在Java中采用接口实现,其中约定红灯时通行的相关接口为:

isEmergent()和runRedLight()。

isEmergent()接口约定应急车辆返回自身紧急情况状态,用bool类型的isEmergency表示:

this.isEmergency,其值在紧急情况下为true,非紧急情况下为false。

runRedLight()接口约定应急车辆在红灯时如何通行(isEmergency为true,则通行,isEmergency为false,和普通车辆一样通行)。

实现Emergency的类有PoliceCar、Ambulance和FireEngine,所以在这三个类中都要实现Emergency中定义的接口。

在Java中,实现接口用implements关键字,后面加上所要实现的接口,即:

交通控制类TraficControlSystem对运行的交通工具进行控制,所有交通工具用Vehicle数组v表示;numVehicles表示交通工具数量;control函数进行控制在紧急情况下应急车辆红灯通行,其他情况按常规通行;add()表示有车辆加入系统,shutDown()表示系统关闭。

Vehicle的子类具体类型有Car、Truck、PoliceCar、Ambulance和FireEngine,所以v[]数组中对象有这些类型的对象,加入v[]时会自动向上转型成为Vehicle类型,Emergency接口的应急车辆有runRedLight()方法,其他Car和Truck只有run()方法。

因此,用for循环中对每个v[i],判定是否是Emergency类型的实例,即是否实现了Emergency。

Java中判断一个对象是否是某个类型的实例用instanceof关键字。

即:

v[i]instanceofEmergency,如果是,说明是应急车辆,接着判定应急车辆的状态,在判定之前先要将应急车辆进行向下转型,Java中向下转型直接在对象前加上用括号括起来的转换的目标类型即可,即:

((Emergency)v[i]).isEmergent(),如果判定为真,执行runRedLight(),判定不成功,则调用run(),调用时动态绑定每个数组元素的实际类型,

需要通过动态类型转换并调用nmRedLight():

主控逻辑代码在main方法中实现。

初始化TraficControlSystem,用tcs表示,调用tcs的add()函数添加具体的交通工具,这里会自动向上转型成为Vehicle类型,调用control()对各车辆进行控制,调用shutDown()系统关闭。

因此,空

(1)和空

(2)需要定义接口isEmergent()和runRedLight(),题目代码中已经给出用分号结尾,所以空

(1)和空

(2)分别为“boolisEmergent()”和“voidrunRedLight()”;空(3)需要继承父类Car和实现接口Emergency,Java中继承釆用extends关键字,即应填入“extendsCarimplementsEmergency”;空(4)要返回应急车辆对象的状态,即填入“this.isEmergency”;空(5)处为动态类型转换后的对象(Emergency)v[i];空(6)处为普通车辆对象v[i]。

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

当前位置:首页 > 小学教育 > 英语

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

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