近年程序员考试考练题训练及答案(2)(测练习题)

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

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

1、近3上半年程序员考试专项习题训练3及答案-下午卷试题一(共15分)阅读以下说明和流程图,填补流程图中的空缺,将解答填入答题纸的对应栏内。【说明】下面流程图的功能是:在给定的两个字符串中查找最长的公共子串,输出该公共子串的长度L及其在各字符串中的起始位置(L=0时不存在公共字串)。例如,字符串the light is not bright tonight ” 与“ Tonight the light is not bright ”的最长公共子串为 the light is not bright?,长度为22,起始位置分别为2和10。设A1:M表示由M个字符A1,A2,,AM依次组成的字符串;B1

2、:N表示由N个字符B1, B2,,BN依次组成的字符串,MN1。本流程图采用的算法是:从最大可能的公共子串长度值开始逐步递减,在A、B字符串中查找是否存在长度为L的公共子串,即在A、B字符串中分别顺序取出长度为L 的子串后,调用过程判断两个长度为L的指定字符串是否完全相同(该过程的流程略)。【流程图】(1) N 或 min(M,N) (2) M-L+1 (3) N-L+1 (4) L-1 (5) L, I, J本题考查对算法流程图的理解和绘制能力。这是程序员必须具有的技能。本题的算法可用来检查某论文是否有大段抄袭了另一论文“the light is not bright tonight是著名的

3、英语绕口令,它与onight the light is not bright大同小异。由于字符串A和B的长度分别为M和N,而且MN1,所以它们的公共子串长度 L必然小于或等于N。题中采用的算法是,从最大可能的公共子串长度值L开始逐步递减,在A、B字符串中查找是否存在长度为L的公共子串。因此初始时,应将min (M, N)送L。或直接将N送L。(1)处应填写N或min(M,N),或其他等价形式。对每个可能的L值,为查看A、B串中是否存在长度为L的公共子串,显然需要执行双重循环。A串中,长度为L的子串起始下标可以从1开始直到M-L+1 (可以用实例来检查其正确性);B串中,长度为L的子串起始下标可

4、以从1开始直到N-L+1。因此双重循环的始值和终值就可以这样确定,即(2)处应填M-L+1,或等价形式;(3)处应填N-L+1或等价形式(注意循环的终值应是最右端子串的下标起始值)。A串中从下标I开始长度为L的子串可以描述为AI:I+L-1; B串中从下标J开始长度为L的子串可以描述为AJ:J+L-1。因此,双重循环体内,需要比较这两个子串(题中采用调用专门的函数过程或子程序来实现)。如果这两个子串比较的结果相同,那么就己经发现了 A、B串中最大长度为L的公共子串,此时,应该输出公共子串的长度值L、在A串中的起始下标I、在B串中的起 始下标J。因此,(5)处应填L, I, J (可不计顺序)。

5、如果这两个子串比较的结果不匹配,那么就需要继续执行循环。如果直到循环结束仍然没有发现匹配子串时,就需要将L减少1 (4)处填L-1或其等价形式)。只要L非0,则还可以继续对新的L值执行双重循环。如果直到L=0,仍没有发现子串匹配,则表示A、B两串没有公共子串。试题二(共15分)阅读以下说明和C函数,填补函数代码中的空缺,将解答填入答题纸的对应栏内, 【说明1】函数f(double eps)的功能是:利用公式计算并返回的近似值。【函数1】【说明2】函数fun(Char *str)的功能是:自左至右顺序取出非空字符串str中的数字字符,形成一个十进制整数(最多8位)。例如,若str中的字符串为iy

6、t?67kpf3g8d5.j4ia2e3p12”, 则函数返回值为67385423。【C函数2】(1)n+2 (2) -s 或-1*s (3) *p!=0或等价形式(4)num* 10或等价形式 (5) p+或等价形式本题考查c语言程序设计基本技能。考生需认真阅读题目中的说明,从而确定代码的运算逻辑,在阅读代码时,还需注意各变量的作用。函数f(double eps)的功能是计算的近似值。观察题中给出的计算公式,可知在循环中n每次递增2,因此空(1)处应填入n+2。由于公式中的各项是正负交替的,因此结合表达式term = S/n可知变量s就是起此作用的。空(2)处应填入-s或-1*s。对于函数f

7、un(char *str),从字符序列中取出数字并组合为一个整数时,对于每个数字,只需将之前获取的部分乘以10再加上该数字的值即可。以67385423为例。67385423 = (0+6)* 10+7)* 10+3)* 10+8)* 10+5)* 10+4)* 10+2)* 10+3函数中的变量i是用来计算位数的,num用来计算所获得的整数值。显然,最多读取字符序列中的前8个数字,或者到达字符序列的末尾(*p!=0)时,计算也需结束。 因此,空(3)处应填入“*p!=0”。根据num的作用,空(4)处应填入“num* 10”。根据指针P的作用,空(5)处的代码应使得p指向下一个字符,因此应填入

8、“ p+”。试题三(共15分)阅读以下说明和C代码,填补代码中的空缺,将解答填入答题纸的对应栏内。【说明】下面的程序代码根据某单位职工的月工资数据文件(名称为Salary.dat,文本文件), 通过调用函数GetlncomeTax计算出每位职工每月需缴纳的个人所得税额并以文件(名称为IncomeTax.dat,文本文件)方式保存。例如,有4个职工工资数据的Salary.dat内容如下,其中第一列为工号(整数),第2列为月工资(实数)。1030001 6200.001030002 5800.002010001 8500.002010010 8000.00相应地,计算所得IncomeTax.dat

9、的内容如下所示,其中第3列为个人所得税额:1030001 6200.00 47.201030002 5800.00 35.942010001 8500.00 233.502010010 8000.00 193.00针对工资薪金收入的个人所得税计算公式为:个人所得税额=应纳税所得额X税率速算扣除数 其中,应纳税所得额=月工资三险一金起征点 税率和速算扣除数分别与不同的应,如表3-1所示。设三险一金为月工资的19%,起征点为3500元。例如,某人月工资为5800元,按规定19%缴纳三险一金,那么:其应纳税所得额X=58005800x19%3500=1198元,对应税率和速算扣除数分别为3%和0元,

10、因此,其个人所得税额为1198X3%-0=35.94元。 【C代码】(1)double GetIncomeTax(double salary)或 double GetlncomeTax(double)(2)!fin或 fin=NULL 或 fin=0(3)!fout 或 fout=NULL 或 fout=0(4)&id, &salary(5)GetlncomeTax(salary)(6)salary *(1-RATE)或等价形式 注:RATE可替换为0.19本题考查c语言程序设计基本技能。考生需认真阅读题目中的说明,以便理解问题并确定代码的运算逻辑,在阅读代码时,还需注意各变量的作用。根据注释

11、,空(1)处应填入double GetIncomeTax(double salary)或double GetlncomeTax(double)”,对函数GetlncomeTax 进行声明。空(2)、(3)处所在的代码是判断文件打开操作是否成功,因此应分别填入“!fin”、“! fout”。根据说明可知,变量id和salary分别表示工号和月工资数。空(4)处所在语句为从文件中读取数据的操作,从fscanf的格式控制串可知读取的两个数是整数和双精度浮点数,则输入表列的两个变量分别为接收整数值的变量id和接收整数值的变量salary,因此空(4)应填入“&id, &salary”。空(5)处所在代

12、码向fout关联的文件写入计算出的所得税额,显然需调用函数GetlncomeTax 来计算,因此应填入 “ GetlncomeTax(salary) ”。空(6)处的代码计算应纳税所得额,根据说明中给出的计算公式及三险一金的计算方法:应纳税所得额=月工资三险一金起征点 空(6)处应填入“salary *(1-RATE)”。试题四(共15分)阅读以下说明和C函数,填补代码中的空缺,将解答填入答题纸的对应栏内。【说明】函数Combine(LinkList La, LinkList Lb)的功能是:将元素呈递减排列的两个含头结点单链表合并为元素值呈递增(或非递减)方式排列的单链表,并返回合并所得单链

13、表的头指针。例如,元素递减排列的单链表La和Lb如图4-1所示,合并所得的单链表如图4-2所示。 【c函数】(1) LinkList (2) pa & pb (3) tp-next(4) tp (5) tp = pa本题考查数据结构应用及C语言实现。链表运算是C程序设计题中常见的考点,需熟练掌握。考生需认真阅读题目中的说朋,以便理解问题并确定代码的运算逻辑,在阅读代码时,还需注意各变量的作用。根据注释,空(1)所在的代码定义指向链表中结点的指针变量,结合链表结点类型的定义,应填入“LinkList ”。由于pa指向La链表的元素结点、pb指向Lb链表的元素结点,空(2)所在的while语句中,

14、是将pa指向结点的数据与pb所指向结点的数据进行比较,因此空(2)处应填 入 pa & pb ,以使运算pa-datapb-data?中的pa和pb为非空指针。从空(3)所在语句的注释可知,需将tp所指结点插入Lc链表的头结点之后,空(3) 处应填入tp-next,空(4)处应填入tp,如下图所示。空(5)所在的while语句处理还有剩余结点的链表,pa是保存指针的临时变量循环中的下面4条语句执行后的链表状态如下图所示。空(5)处应填入“ tp = pa”,以继续上述的重复处理过程。 试题五(共15分)阅读下列说明和C+代码,填补代码中的空缺,将解答填入答题纸的对应栏内。【说明】设计RGB方式

15、表示颜色的调色板,进行绘图,其类图如图5-1所示9该程序的C+ 代码附后。【C+代码】(1) free(palette) (2) this-number (3) static const(4) new MyColor (5) new Drawing()本题考查C+程序设计的能力,涉及类、对象、方法定义和相关操作、要求考生根据给出的案例和代码说明,认真阅读并理清程序思路,然后完成题目。先考查题目说明。本题目中涉及到颜色、调色板、绘图等类以及初始化和调色相关等操作。根据说明进行设计。类图中给出三个类Drawing、Palette和MyColor及其之间的关系。Drawing与Palette、MyColor之间具有关联关系,Palette与MyColor之间是聚合关系。MyColor为以RGB方式表不颜色,由属性red、green和blue表示,每个MyColor对象即为一个RGB颜色。MyColor具有两个构造器,缺省构造器将RGB颜色均初始化为0;带参数的构造方法将当前对象的RGB值设置为调用构造方法时消息中所传递的参数值。pr

展开阅读全文
相关资源
相关搜索

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

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