最近程序员考试测练考题及答案(3)(考练提升)

上传人:lili****2007 文档编号:235725595 上传时间:2022-01-06 格式:DOC 页数:19 大小:902KB
返回 下载 相关 举报
最近程序员考试测练考题及答案(3)(考练提升)_第1页
第1页 / 共19页
最近程序员考试测练考题及答案(3)(考练提升)_第2页
第2页 / 共19页
最近程序员考试测练考题及答案(3)(考练提升)_第3页
第3页 / 共19页
亲,该文档总共19页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《最近程序员考试测练考题及答案(3)(考练提升)》由会员分享,可在线阅读,更多相关《最近程序员考试测练考题及答案(3)(考练提升)(19页珍藏版)》请在金锄头文库上搜索。

1、习题很丰富,梦想易实现。近几年程序员考试专题训练1及答案试题一【说明】两个包含有限个元素的非空集合A、B的相似度定义为|AB|/|AB|,即它们的交集大小(元素个数)与并集大小之比。以下的流程图计算两个非空整数集合(以数组表示)的交集和并集,并计算其相似度。已知整数组A1:m和B1:n分别存储了集合A和B的元素(每个集合中包含的元素各不相同),其交集存放于数组C1:s,并集存放于数组D1: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)(

2、5),将解答填入答题纸的对应栏内。答案解析:(1)s (2)t (3)Cs (4)Dt (5)s/t本题考査程序处理流程图的设计能力。首先我们来理解两个有限集合的相似度的含义。两个包含有限个元素的非空集合A、B的相似度定义为它们的交集大小(元素个数)与并集大小之比。如果两集合完全相等,则相似度必然为1(100%);如果两集合完全不同(没有公共元素),则相似度必然为0;如果集合A中有一半元素就是集合B的全部元素,而另一半元素不属于集合B,则这两个集合的相似度为0.5(50%)。因此,这个定义符合人们的常理性认识。在大数据应用中,经常要将很多有限集进行分类。例如,每天都有大量的新闻稿。为了方便用户

3、检索,需要将新闻稿分类。用什么标准来分类呢?每一篇新闻稿可以用其中所有的关键词来表征。这些关键词的集合称为这篇新闻稿的特征向量。两篇新闻稿是否属于同一类,依赖于它们的关键词集合是否具有较高的相似度(公共关键词个数除以总关键词个数)。搜索引擎可以将相似度超过一定水平的新闻稿作为同一类。从而,可以将每天的新闻稿进行分类,就可以按用户的需要将某些类的新闻稿推送给相关的用户。本题中的集合用整数组表示,因此,需要规定同一数组中的元素各不相同(集合中的元素是各不相同的)。题中,整数组A1:m和B1:n分别存储了集合A和B的元素。流程图的目标是将A、B中相同的元素存放入数组C1:s(共s个元素),并将A、B

4、中的所有元素(相同元素只取一次)存放入数组D1:t(共t个元素),最后再计算集合A和B相似度s/t。流程图中的第一步显然是将数组A中的全部元素放入数组D中。随后,只需要对数组B中的每个元素进行判断,凡与数组A中某个元素相同时,就将其存入数组C;否则就续存入数组D(注意,数组D中已有m个元素)。这需要对j(遍历数组B)与i(遍历数组A)进行两重循环。判断框Bj=Ai成立时,Bj应存入数组C;否则应继续i循环,直到循环结束仍没有相等情况出现时,就应将Bj存入数组D。存入数组C之前,需要将其下标s增1;存入数组D之前,需要将其下标t增1。因此,初始时,应当给j赋0,使数组C的存数从Cl开始。从而,(

5、1)处应填s,(3)处应填Cs。而数组D是在已有m个元素后续存,所以,初始时,数组D的下标t应当是m,续存是从Dm+1幵始的。因此,(2)处应填t,(4)处应填Dt。两重循环结束后,就要计算相似度s/t,将其赋予SIM,因此(5)处应填s/t。试题二【说明】下面的函数sort(intn,inta)对保存在数组a中的整数序列进行非递减排序。由于该序列中的元素在一定范围内重复取值,因此排序方法是先计算出每个元素出现的次数并记录在数组b中,再从小到大顺序地排列各元素即可得到一个非递减有序序列。例如,对于序列6,5,6,9,6,4,8,6,5,其元素在整数区间4,9内取值,因此使数组元素b0b5的下标

6、05分别对应数值49,顺序地扫描序列的每一个元素并累计其出现的次数,即将4的个数记入b0,5的个数记入b1,依此类推,9的个数记入b5。最后依次判断数组b的每个元素值,并将相应个数的数值顺序地写入结果序列即可。对于上例,所得数组b的各个元素值如下:那么在输出序列中写入1个4、2个5、4个6、1个8、1个9,即得4,5,5,6,6,6,6,8,9,从而完成排序处理。【C函数】 阅读以上说明和C函数,填充函数中的空缺,将解答填入答题纸的对应栏内。答案解析:(1)afiminimum,或aimaximum,或ai=maximum,或其等价形式(3)0(4)bk,或bk0,或bk!=0,或其等价形式(

7、5)k本题考查C程序的基本语法和运算逻辑。首先应认真分析题目中的说明,然后确定代码结构和各变量的作用。空(1)和(2)所在for语句的功能是求出数组a中的最小元素minimum和最大元素maximum。在设置了minimum和maximum的初始值后,空(1)处的判断条件是只要目前的元素ai小于minimum,就需要更新minimum,反之,空(2)处的判断条件是只要目前的元素ai大于maximum,就需要更新maximum,因此空(1)处应填入aimaximum或其等价方式。minimum和maximum的作用是要确定计数数组b的大小。根据题目中的描述,序列中的每个元素ai都对应到计数数组b

8、的一个元素bk,对应方式为:k=ai-minimum,其中minimum是数组a中的最小元素,显然在计数时,一个数值出现一次,就在对应的bk中累加一次。空(3)(5)所在的语句组是产生排序后的序列,重新写入数组a。首先需明确变量i和k的作用,根据它们在该语句组中的出现位置,i用于表示数组a的元素下标,k用于表示数组b中元素的下标,因此,空(3)处应填入0,使得从数组a中下标为0的数组元素开始。通过循环控制“for(k=0;k0”或其等价形式。由于bk中记录的是元素k+minimum的出现次数,所以空(5)处应填入k,从而将元素值恢复后再写回去。 试题三【说明1】F面的函数countChar(c

9、har*text)统计字符串text中不同的英文字母数和每个英文字母出现的次数(英文字母不区分大小写)。【C代码1】【说明2】将下面C代码2中的空缺补全后运行,使其产生以下输出。f2:f2:f2:2f3:f3:1【C代码2】 阅读以上说明和C代码,填充代码中的空缺,将解答填入答题纸的对应栏内。答案解析:(1)text,或&text0,或其等价形式(2)ptr+,或+ptr,或ptr=ptr+l,或ptr+=l(3)ci,或*(c+i)(4)f2(5)f3(6)f(n),或(*f)(n)本题考查数据指针、运算逻辑和函数指针的应用。首先应认真分析题目中的说明,然后确定代码结构和各变量的作用。在函数

10、countChar(char*text)中来统计字符串text中不同的英文字母数和每个英文字母出现的次数。用来表示计数值的数组元素ci需要与英文字母对应起来,方式为c0记录字母A或a的次数,cl记录字母B或b的次数,依此类推,因此i=英文字母-A(英文字母为大写)或i=英文字母-a(英文字母为小写)。数据指针是指向数据的指针变量。数据指针ptr用来表示text中的每一个字符,初始时ptr指向第一个字符,因此空(1)处应填入“text”或其等价方式,(2)处的作用是随循环控制逐个指出text中的后续字符,因此空(2)处应填入“ptr+”或其等价方式。显然,若ci的值不为0则表示字符A+i或a+i

11、出现了,反之,则表示字符A+i或a+i未出现,因此在计算字符种类时只要判断ci是否为0即可,因此空(3)处应填入“ci”或其等价形式。函数指针是指向函数的指针变量。根据代码2的声明“intfl(int(*f)(int);w可知调用函数fl时,实参应该是函数名或函数指针,且函数名或函数指针指向的函数应有一个整型参数,返回值为整型,而f2和fi都是符合这种定义类型的函数。C代码2中,在main函数中两次调用了函数fl,分析运行结果可知,是先以f2为实参调用fl,然后以fi为实参调用fl,因此空(4)和(5)分别填入“f2”或“f3”或它们的等价形式,在空(6)处应填入“f(n)”或其等价形式来实现

12、最后对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

13、程序】 阅读以上说明和C程序,填充程序中的空缺,将解答填入答题纸的对应栏内。答案解析:(1)a%10,或其等价形式(2)right(rs,len)(3)num%10,或其等价形式(4)ch=si,或ch=*(s+i)(5)i+,ms-,或ms-,i+,或其等价形式本题考查C语言语法、数据指针和运算逻辑的应用。首先应认真分析题目中的说明,然后确定代码结构和各变量的作用。根据题目中的叙述,同构数的个位数为1、5或6,因此,对于不超过10000的每个整数,应先获取其个位数字,因此空(1)处应填入“a%10”或其等价形式,从而可以先过滤掉不可能是同构数的数。根据代码中的注释,通过以下运算后,得到由a中

14、数值转换所得的字符串as,以及a的平方所得数值转换得到的字符串rs,此后通过字符串比较运算来判断是否为同构数。函数myitoa(int num,char*s)的功能是将整数num转换为字符串s,这就需要将整数num的每个数字分离出来,通常通过整除取余运算实现,即以下代码所实现的。其中,空(3)处应填入“num%10”或其等价形式。函数right(char*ms,int length)取字符串ms尾部长度为length的子串,返回所得子串的首字符指针。该函数的处理思路是先找到ms中字符串的结尾,然后倒着数出length个字符,从而得到所需字符串的首字符指针。空(5)处应填入“i+,ms-”或其等价形式。另一个更简便的方式是在得到ms的结尾指针后,再减去length即可,即最后返回ms-length即可。 试题五【说明】某应急交通控制系统(TraficControlSystem)在红灯时控制各类车辆(Vehicle)的通行,其类图如图5-1所示,在紧急状态下应急车辆红灯时也可通行,其余车辆按正常规则通行。下面的C+代码实现以上设计,请完善其中的空缺。 阅读以下说明和C+代码,填充代码中的空缺,将解答填入答题纸的对应栏内。答案解析:(1)virtual bool isEmergent()(2)virtual void runRedLight()(3)public

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 资格认证/考试 > 网络工程师认证

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号