全国计算机技术与软件专业技术资格(水平)考试

全国计算机技术与软件专业技术资格(水平)考试

欢迎访问软件考试网(www.hbsoft.net)

2006年上半年软件设计师上午试卷

●两个同符号的数相加或异符号的数相减,所得结果的符号位SF和进位标志CF进行(1)运算为1时,表示运算的结果产生溢出。

(1)A.与B.或C.与非D.异或

●若浮点数的阶码用移码表示,尾数用补码表示。两规格化浮点数相乘,最后对结果规格化时,右规的右移位数最多为(2)位。

(2)A.1B.2C.尾数位数D.尾数位数-1

(3)A.90B.95C.97D.99

(4)A.488888B.388888C.288888D.188888

(5)A.2×104B.5×104C.2×105D.5×105

连续输入10条指令时的吞吐率为(6)。

(6)A.10/70△tB.10/49△tC.10/35△tD.10/30△t

●相对于DES算法而言,RSA算法的(7),因此,RSA(8)。

(7)A.加密密钥和解密密钥是不相同的B.加密密钥和解密密钥是相同的

C.加密速度比DES要高D.解密速度比DES要高

(8)A.更适用于对文件加密B.保密性不如DES

C.可用于对不同长度的消息生成消息摘要D.可以用于数字签名

(9)A.网上冲浪B.中间人攻击C.DDoS攻击D.MAC攻击

●上海市标准化行政主管部门制定并发布的工业产品的安全、卫生要求的标准,在其行政区域内是(10)。欢迎访问软件考试网(www.hbsoft.net)

(10)A.强制性标准B.推荐性标准C.自愿性标准D.指导性标准

●小王购买了一个“海之久”牌活动硬盘,而且该活动硬盘还包含有一项实用新型专利,那么,小王享有(11)。欢迎访问软件考试网(www.hbsoft.net)

(11)A.“海之久”商标专用权B.该盘的所有权

C.该盘的实用新型专利权D.前三项权利之全部

●MPC(MultimediaPC)与PC的主要区别是增加了(12)。

(12)A.存储信息的实体B.视频和音频信息的处理能力

C.光驱和声卡D.大容量的磁介质和光介质

●人眼看到的任一彩色光都是亮度、色调和饱和度三个特性的综合效果,其中(13)反应颜色的种类。欢迎访问软件考试网(www.hbsoft.net)

(13)A.色调B.饱和度C.灰度D.亮度

●CD上声音的采样频率为44.1kHz,样本精度为16b/s,双声道立体声,那么其未经压缩的数据传输率为(14)。欢迎访问软件考试网(www.hbsoft.net)

(14)A.88.2kb/sB.705.6kb/sC.1411.2kb/sD.1536.0kb/s

●在软件项目管理中可以使用各种图形工具来辅助决策,下面对Gantt图的描述中,不正确的是(15)。欢迎访问软件考试网(www.hbsoft.net)

C.Gantt图反映了各个活动之间的依赖关系

D.Gantt图表现了完成各个活动的进度

●耦合度描述了(16)。欢迎访问软件考试网(www.hbsoft.net)

(16)A.模块内各种元素结合的程度

B.模块内多个功能之间的接口

C.模块之间公共数据的数量

D.模块之间相互关联的程度

●内聚是一种指标,表示一个模块(17)。

(17)A.代码优化的程度B.代码功能的集中程度

C.完成任务的及时程度D.为了与其他模块连接所要完成的工作量

●在软件项目开发过程中,评估软件项目风险时,(18)与风险无关。

(18)A.高级管理人员是否正式承诺支持该项目

B.开发人员和用户是否充分理解系统的需求

C.最终用户是否同意部署已开发的系统

D.开发需要的资金是否能按时到位

●开发专家系统时,通过描述事实和规则由模式匹配得出结论,这种情况下适用的开发语言是(19)。欢迎访问软件考试网(www.hbsoft.net)

(19)A.面向对象语言B.函数式语言C.过程式语言D.逻辑式语言

●高级程序设计语言中用于描述程序中的运算步骤、控制结构及数据传输的是(20)。欢迎访问软件考试网(www.hbsoft.net)

(20)A.语句B.语义C.语用D.语法

●为了解决进程间的同步和互斥问题,通常采用一种称为(21)机制的方法。若系统中有5个进程共享若干个资源R,每个进程都需要4个资源R,那么使系统不发生死锁的资源R的最少数目是(22)。欢迎访问软件考试网(www.hbsoft.net)

(21)A.调度B.信号量C.分派D.通讯

(22)A.20B.18C.16D.15

●在UNIX操作系统中,把输入/输出设备看作是(23)。

(23)A.普通文件B.目录文件C.索引文件D.特殊文件

(24)A.17500msB.15000msC.5000msD.25000ms

●文件系统中,设立打开文件(Open)系统功能调用的基本操作是(25)。

(25)A.把文件信息从辅存读到内存

B.把文件的控制管理信息从辅存读到内存

C.把磁盘的超级块从辅存读到内存

D.把文件的FAT表信息从辅存读到内存

●最主要的软件质量度量指标有正确性、可维护性、完整性和可用性,下面关于这些质量指标的描述中正确的是(26)。

(26)A.软件维护的工作量比开发阶段的工作量小

B.正确性用每千行代码的故障(fault)数来度量

C.软件完整性是指软件功能与需求符合的程度

D.可用性与用户的操作效率和用户对软件的主观评价有关

(27)A.7B.9C.12D.13

●正式的技术评审FTR(FormalTechnicalReview)是软件工程师组织的软件质量保证活动,下面关于FTR指导原则中不正确的是(28)。

(28)A.评审产品,而不是评审生产者的能力

B.要有严格的评审计划,并遵守日程安排

C.对评审中出现的问题要充分讨论,以求彻底解决

D.限制参与者人数,并要求评审会之前做好准备

●两个小组独立地测试同一个程序,第一组发现25个错误,第二组发现30个错误,在两个小组发现的错误中有15个是共同的,那么可以估计程序中的错误总数是(29)个。

(29)A.25B.30C.50D.60

●下面有关测试的说法正确的是(30)。

(30)A.测试人员应该在软件开发结束后开始介入

B.测试主要是软件开发人员的工作

C.要根据软件详细设计中设计的各种合理数据设计测试用例

D.严格按照测试计划进行,避免测试的随意性

●在绘制数据流图时,应遵循父图与子图平衡的原则,所谓平衡是指(31)。

(31)A.父图和子图都不得改变数据流的性质

B.子图不改变父图数据流的一致性

C.父图的输入/输出数据流与子图的输入/输出数据流一致

D.子图的输出数据流完全由父图的输入数据流确定

●下图中的程序由A、B、C、D、E5个模块组成,下表中描述了这些模块之间的接口,每一个接口有一个编号。此外,模块A、D和E都要引用一个专用数据区。那么A和E之间耦合关系是(32)。欢迎访问软件考试网(www.hbsoft.net)

编号

参数

返回值

1

数据项

2

3

功能码

4

列表

(32)A.公共耦合B.数据耦合C.内容耦合D.无耦合

●在C++语言中,若类C中定义了一个方法intf(inta,intb),那么方法(33)不能与该方法同时存在于类C中。

(33)A.intf(intx,inty)B.intf(floata,intb)

C.floatf(intx,floaty)D.intf(intx,floaty)

●已知3个类O、P和Q,类O中定义了一个私有方法F1、一个公有方法F2和一个受保护的方法F3;类P和类Q是类O的派生类,其继承方式如下所示:

classP:protectedO{…};欢迎访问软件考试网(www.hbsoft.net)

classQ:publicO{…};

关于方法F1的描述中正确的是(34);关于方法F2的描述中正确的是(35);关于方法F3的描述中正确的是(36)。

(34)A.方法F1无法被访问欢迎访问软件考试网(www.hbsoft.net)

B.只有在类O内才能访问方法F1

C.只有在类P内才能访问方法F1

D.只有在类Q内才能访问方法F1

(35)A.类O、P和Q的对象都可以访问方法F2

B.类P和Q的对象都可以访问方法F2

C.类O和Q的对象都可以访问方法F2

D.只有在类P内才能访问方法F2

(36)A.类O、P和Q的对象都可以访问方法F3

B.类O、P和Q的对象都不可以访问方法F3

C.类O和Q的对象都可以访问方法F3

D.类P和Q的对象都可以访问方法F3

●在面向对象软件开发过程中,采用设计模式(37)。

(37)A.允许在非面向对象程序设计语言中使用面向对象的概念

B.以复用成功的设计和体系结构

C.以减少设计过程创建的类的个数

D.以保证程序的运行速度达到最优值

●以下关于单身模式(Singleton)的描述中,正确的是(38)。

(38)A.它描述了只有一个方法的类的集合

B.它能够保证一个类只产生一个唯一的实例

C.它描述了只有一个属性的类的集合

D.它能够保证一个类的方法只能被一个唯一的类调用

●下列关于一个类的静态成员的描述中,不正确的是(39)。

(39)A.该类的对象共享其静态成员变量的值

B.静态成员变量可被该类的所有方法访问

C.该类的静态方法只能访问该类的静态成员变量

D.该类的静态数据成员变量的值不可修改

●在MVC(模型/视图/控制器)模式中,视图部分描述的是(40)。

(40)A.将应用问题域中包含的抽象领域知识呈现给用户的方式

B.应用问题域中所包含的抽象类

C.用户界面对用户输入的响应方式

D.应用问题域中包含的抽象领域知识

●对于如下所示的UML类图,正确的描述是(41)。

(41)A.类B的实例中包含了对类C的实例的引用

B.类A的实例中包含了对类B的实例的引用

C.类A的实例中包含了对类C的实例的引用

D.类B的实例中包含了对类A的实例的引用

●UML中关联的多重度是指(42)。欢迎访问软件考试网(www.hbsoft.net)

(42)A.一个类有多少个方法被另一个类调用

C.一个类的某个方法被另一个类调用的次数

D.两个类所具有的相同的方法和属性

●已知3个类A、B和C,其中类A由类B的一个实例和类C的1个或多个实例构成。能够正确表示类A、B和C之间关系的UML类图是(43)。

(43)A.B.

C.D.

●对于下面的文法G[S],(44)是其句子(从S出发开始推导)。

G[S]:S→M|(S,M)M→P|MPP→a|b|c|...|x|x|z

(44)A.((a,f))B.((fac,bb),g)C.(abc)D.(c,(da))

●与逆波兰式ab+-c*d-对应的中缀表达式是(45)。

(45)A.a-b-c*dB.-(a+b)*c-dC.-a+b*c-dD.(a+b)*(-c-d)

●下面的C程序代码段在运行中会出现(46)错误。

inti=0;欢迎访问软件考试网(www.hbsoft.net)

while(i<10);

{i=i+1;}欢迎访问软件考试网(www.hbsoft.net)

(46)A.语法B.类型不匹配C.变量定义D.动态语义

●设有关系R、S如下所示,则关系代数表达式的结果集为(47)。

关系R

关系S

A

B

C

D

a1

b1

c1

d1

b2

a2

c2

(47)

A.

B.

C.

D.

●某数据库中有员工关系E、产品关系P、仓库关系W和库存关系I,其中:员工关系E(employeeID,name,department)中的属性为:员工编号,姓名,部门;产品关系P(productID,name,model,size,color)中的属性为:产品编号,产品名称,型号,尺寸,颜色;仓库关系W(warehouseID,name,address,employeeID)中的属性为:仓库编号,仓库名称,地址,负责人编号;库存关系I(warehouseID,productID,quantity)中的属性为仓库编号,产品编号和产品数量。a.若要求仓库关系的负责人引用员工关系的员工编号,员工关系E的员工编号、仓库关系W的仓库编号和产品关系P的产品编号不能为空且惟一标识一个记录,并且仓库的地址不能为空,则依次要满足的完整性约束是(48)。

(48)A.实体完整性、参照完整性、用户定义完整性

B.参照完整性、实体完整性、用户定义完整性

C.用户定义完整性、实体完整性、参照完整性

D.实体完整性、用户定义完整性、参照完整性

b.若需得到每种产品的名称和该产品的总库存量,则对应的查询语句为:

SELELCTname,SUM(quantity)

FROMP,I

WHERE(49)欢迎访问软件考试网(www.hbsoft.net)

(49)A.P.productID=I.productID;

B.P.productID=I.productIDORDERBYname;

C.P.productID=I.productIDGROUPBYname;

D.P.productID=I.productIDGROUPBYname,quantity;

c.若需得到在所有仓库中都存在的产品的名称,则对应的查询语句为:

SELECTnameFROMP

WHERE(50)欢迎访问软件考试网(www.hbsoft.net)

(SELECT*FROMW

WHERENOTEXISTS

(SELECT*FROMI

WHEREP.productID=I.productIDANDW.warehouseID=I.warehouseID))

(50)A.EXISTSB.NOTEXISTSC.IND.NOTIN

●对事务回滚的正确描述是(51)。欢迎访问软件考试网(www.hbsoft.net)

(51)A.将该事务对数据库的修改进行恢复

B.将事务对数据库的更新写入硬盘

C.跳转到事务程序的开头重新执行

D.将事务中修改的变量值恢复到事务开始时的初值

●拓扑序列是无环有向图中所有顶点的一个线性序列,图中任意路径中的各个顶点在该图的拓扑序列中保持先后关系,(52)为下图所示有向图的一个拓扑序列。

(52)A.1234567B.1526374C.5126347D.5123764

●为便于存储和处理一般树结构形式的信息,常采用孩子-兄弟表示法将其转换成二叉树(左子关系表示父子、右子关系表示兄弟),与下图所示的树对应的二叉树是(53)。欢迎访问软件考试网(www.hbsoft.net)

(53)

●给定一个有n个元素的有序线性表。若采用顺序存储结构,则在等概率前提下,删除其中的一个元素平均需要移动(54)个元素。

(54)A.B.C.D.1

●在平衡二叉树中,(55)。欢迎访问软件考试网(www.hbsoft.net)

(55)A.任意结点的左、右子树结点数目相同

B.任意结点的左、右子树高度相同

C.任意结点的左右子树高度之差的绝对值不大于1

D.不存在度为1的结点

●在(56)存储结构中,数据结构中元素的存储地址与其关键字之间存在某种映射关系。欢迎访问软件考试网(www.hbsoft.net)

(56)A.顺序(Sequence)B.链表(Link)

C.索引(Index)D.散列(Hash)

(57)A.分治B.贪心C.动态规划D.分支-限界

(58)A.3B.4C.5D.6

(59)A.B.C.D.

(60)A.插入排序B.归并排序C.快速排序D.堆排序

●与多模光纤相比较,单模光纤具有(61)等特点。

(61)A.较高的传输率、较长的传输距离、较高的成本

B.较低的传输率、较短的传输距离、较高的成本

C.较高的传输率、较短的传输距离、较低的成本

D.较低的传输率、较长的传输距离、较低的成本

●CDMA系统中使用的多路复用技术是(62)。我国自行研制的移动通信3G标准是(63)。欢迎访问软件考试网(www.hbsoft.net)

(62)A.时分多路B.波分多路C.码分多址D.空分多址

(63)A.TD-SCDMAB.WCDMA

C.CDMA2000D.GPRS

●“science”是XML中一个元素的定义,其中元素的内容是(64)。欢迎访问软件考试网(www.hbsoft.net)

(64)A.titleB.styleC.italicD.science

●某校园网用户无法访问外部站点210.102.58.74,管理人员在Windows操作系统下可以使用(65)判断故障发生在校园网内还是校园网外。

(65)A.ping210.102.58.74B.tracert210.102.58.74

C.netstat210.102.58.74D.arp210.102.58.74

●OriginallyintroducedbyNetscapeCommunications,(66)areageneralmechanismwhichHTTPServersideapplications,suchasCGI(67),canusetobothstoreandretrieveinformationontheHTTP(68)sideoftheconnection.Basically,Cookiescanbeusedtocompensateforthe(69)natureofHTTP.Theadditionofasimple,persistent,client-sidestatesignificantlyextendsthecapabilitiesofWWW-based(70).

(66)A.BrowsersB.CookiesC.ConnectionsD.Scripts

(67)A.graphicsB.processesC.scriptsD.texts

(68)A.ClientB.EditorC.CreatorD.Server

(69)A.fixedB.flexibleC.stableD.stateless

(70)A.programsB.applicationsC.frameworksD.constrains

●WebSQLisaSQL-like(71)languageforextractinginformationfromtheweb.Itscapabilitiesforperformingnavigationofweb(72)makeitausefultoolforautomatingseveralweb-relatedtasksthatrequirethesystematicprocessingofeitherallthelinksina(73),allthepagesthatcanbereachedfromagivenURLthrough(74)thatmatchapattern,oracombinationofboth.WebSQLalsoprovidestransparentaccesstoindexserversthatcanbequeriedviatheCommon(75)Interface.

(71)A.queryB.transactionC.communicationD.programming

(72)A.browsersB.serversC.hypertextsD.clients

(73)A.hypertextB.pageC.protocolD.operation

(74)A.pathsB.chipsC.toolsD.directories

(75)A.RouterB.DeviceC.ComputerD.Gateway

下午试卷

试题一(15分)欢迎访问软件考试网(www.hbsoft.net)

阅读下列说明以及数据流图,回答问题1、问题2和问题3,将解答填入答题纸的对应栏内。

【说明】欢迎访问软件考试网(www.hbsoft.net)

某学校建立了一个网上作业提交与管理系统,基本功能描述如下:

(3)在线批阅。系统自动在线批改作业,显示作业成绩,并将该成绩记录在作业成绩统计文件中。

【问题1】(3分)欢迎访问软件考试网(www.hbsoft.net)

如果将数据库服务器(记为DB)作为一个外部实体,那么在绘制该系统的数据流图时,还应有哪些外部实体和数据存储?

【问题2】(7分)欢迎访问软件考试网(www.hbsoft.net)

根据说明结合问题1的解答,指出在该系统的顶层数据流图中应有哪些数据流。请采用说明中的词汇给出这些数据流的起点、终点以及数据流名称,下表给出了数据流的部分信息,请填充空缺处。

序号

起点

终点

数据流名称

(1)

网上作业提交与管理系统

作业申请

(2)

提交的作业

(3)

需完成的作业

(4)

(5)

5

(6)

6

(7)

(8)

7

(9)

选课学生名单

8

(10)

(11)

9

(12)

帐号和密码

10

(13)

【问题3】(5分)欢迎访问软件考试网(www.hbsoft.net)

根据数据流图的设计原则,阅读下图所示的数据流图,找出其中的错误之处。

试题二(15分)欢迎访问软件考试网(www.hbsoft.net)

阅读下列说明以及UML类图,回答问题1、问题2和问题3,将解答填入答题纸的对应栏内。

【说明】

某客户信息管理系统中保存着两类客户的信息:

该系统除了可以保存客户信息之外,还具有以下功能:

(1)向系统中添加客户(addCustomer);

(2)根据给定的客户标识,在系统中查找该客户(getCustomer);

(3)根据给定的客户标识,从系统中删除该客户(removeCustomer);

(4)创建新的联系人(addContact);

(5)在系统中查找指定的联系人(getContact);

(6)从系统中删除指定的联系人(removeContact)。

该系统采用面向对象方法进行开发。在面向对象分析阶段,根据上述描述,得到如表2-1所示的类。欢迎访问软件考试网(www.hbsoft.net)

表2-1

类名

说明

CustomerInformationSystem

客户信息管理系统

IndividualCustomer

个人客户

InstitutionalCustomer

集团客户

Contact

联系人

描述该客户信息管理系统的UML类图如图2-1所示。欢迎访问软件考试网(www.hbsoft.net)

图2-1客户信息管理系统的UML类图

【问题1】(3分)

请使用说明中的术语,给出图2-1中类Customer和类Person的属性。

【问题2】(6分)

识别关联的多重度是面向对象建模过程中的一个重要步骤。根据说明中给出的描述,完成图中的(1)~(6)。

【问题3】(6分)

根据说明中的叙述,抽象出如表2-2所示的方法,请指出图2-1中的类CustomerInformationSystem和InstitutionalCustomer应分别具有其中的哪些方法。

表2-2

功能描述

方法名

向系统中添加客户

addCustomer

根据给定的客户标识,在系统中查找该客户

getCustomer

根据给定的客户标识,从系统中删除该客户

removeCustomer

创建新的联系人

addContact

在系统中查找指定的联系人

getContact

从系统中删除指定的联系人

removeContact

试题三(15分)

阅读下列说明,回答问题1、问题2和问题3,将解答填入答题纸的对应栏内。

某单位资料室需要建立一个图书管理系统,初步的需求分析结果如下:

(1)资料室有图书管理员若干名,他们负责已购入图书的编目和借还工作,每名图书管理员的信息包括工号和姓名;

(3)每部书在系统中对应惟一的一条图书在版编目数据(CIP,以下简称书目),书目的基本信息包括ISBN号、书名、作者、出版商、出版年月,以及本资料室拥有该书的册数(以下简称册数),不同书目的ISBN号不相同;

(4)资料室对于同一书目的图书可拥有多册(本),图书信息包括图书ID、ISBN号、存放位置、当前状态,每一本书在系统中被赋予惟一的图书ID;

某书目的信息如表3-1所示,与该书目对应的图书信息如表3-2所示。

表3-1书目信息

书名

作者

出版商

ISBN号

出版年月

册数

经办人

《数据结构》

严蔚敏

吴伟民

清华大学出版社

ISBN7-302-02368-9

1997.4

01

表3-2图书信息

图书ID

存放位置

状态

C832.1

图书流通室

已借出

C832.2

图书阅览室

不外借

C832.3

未借出

C832.4

已预约

系统的主要业务处理如下:

(1)入库管理:图书购进入库时,管理员查询本资料室的书目信息,若该书的书目尚未建立,则由管理员编写该书的书目信息并录入系统,然后编写并录入图书信息;否则,修改该书目的册数,然后编写并录入图书信息,对于进入流通室的书,其初始状态为“未借出”,而送入阅览室的书的状态始终为“不外借”。

(2)借书管理:读者借书时,若有,则由管理员为该读者办理借书手续,并记录该读者的借书信息,同时将借出图书的状态修改为“已借出”。

(5)通知处理:对于已到期且未归还的图书,系统通过Email自动通知读者;若读者预约的书已到,系统则自动通过Email通知该读者来办理借书手续。

【问题1】(4分)

根据以上说明设计的实体联系图如图3-1所示,请指出读者与图书、书目与读者、书目与图书之间的联系类型。

图3-1图书管理系统的实体联系图

【问题2】(4分)

该图书管理系统的主要关系模式如下,请补充“借还记录”和“预约登记”关系中的空缺。

管理员(工号,姓名)

书目(ISBN号,书名,作者,出版商,出版年月,册数,经办人)

图书(图书ID,ISBN号,存放位置,状态,经办人)

【问题3】(7分)请指出问题2中给出的读者、书目关系模式的主键,以及图书、借还记录和预约登记关系模式的主键和外键。

试题四(15分)

阅读以下说明,回答问题1、问题2和问题3,将解答填入答题纸的对应栏内。

某单位正在使用一套C/S模式的应用软件系统,现在需要升级为B/S应用模式,但需要保持业务的连续性。开发人员提出用WebService作为中间层的接口进行开发。

【问题1】(6分)

【问题2】(3分)

WebService的三个基本技术是WSDL、SOAP、UDDI,它们都是以XML为基础定义的。请用120字以内文字,简要说明WSDL、SOAP和UDDI的作用。

服务注册中心、服务提供者和服务请求者之间的交互和操作构成了WebService的体系结构,如图4-1所示。请用180字以内文字,说明这三者的主要功能及其交互过程。

图4-1WebService的工作模式

试题五(15分)

阅读下列说明、图和C代码,将应填入(n)处的字句写在答题纸的对应栏内。

【说明5-1】

B树是一种多叉平衡查找树。一棵m阶的B树,或为空树,或为满足下列特性的m叉树:

①树中每个结点至多有m棵子树;

②若根结点不是叶子结点,则它至少有两棵子树;

③除根之外的所有非叶子结点至少有棵子树;

④所有的非叶子结点中包含下列数据信息

(n,A0,K1,A1,K2,A2,…,Kn,An)

其中:Ki(i=1,2,……,n)为关键字,且Ki

⑤所有的叶子结点都出现在同一层次上,并且不带信息(可以看作是外部结点或查找失败的结点,实际上这些结点不存在,指向这些结点的指针为空)。

例如,一棵4阶B树如图5-1所示(结点中关键字的数目省略)。

图5-14阶B树示例

B树的阶M、bool类型、关键字类型及B树结点的定义如下:

#defineM4/*B树的阶*/

typedefenum{FALSE=0,TRUE=1}bool;

typedefintElemKeyType;

typedefstructBTreeNode{

intnumkeys;/*结点中关键字的数目*/

structBTreeNode*parent;/*指向父结点的指针,树根的父结点指针为空*/

structBTreeNode*A[M];/*指向子树结点的指针数组*/

ElemKeyTypeK[M];/*存储关键字的数组,K[0]闲置不用*/

}BTreeNode;

函数SearchBtree(BTreeNode*root,ElemKeyTypeakey,BTreeNode**ptr)的功能是:在给定的一棵M阶B树中查找关键字akey所在结点,若找到则返回TRUE,否则返回FALSE。其中,root是指向该M阶B树根结点的指针,参数ptr返回akey所在结点的指针,若akey不在该B树中,则ptr返回查找失败时空指针所在结点的指针。例如,在图5-1所示的4阶B树中查找关键字25时,ptr返回指向结点e的指针。

注:在结点中查找关键字akey时采用二分法。

【函数5-1】

boolSearchBtree(BTreeNode*root,ElemKeyTypeakey,BTreeNode**ptr)

{

intlw,hi,mid;

BTreeNode*p=root;

*ptr=NULL;

while(p){

lw=1;hi=(1);

while(lw<=hi){

mid=(lw+hi)/2;

if(p->K[mid]==akey){

*ptr=p;

returnTRUE;

}

else

if((2))

hi=mid-1;

lw=mid+1;

p=(3);

returnFALSE;

【说明5-2】

在M阶B树中插入一个关键字时,首先在最接近外部结点的某个非叶子结点中增加一个关键字,若该结点中关键字的个数不超过M-1,则完成插入;否则,要进行结点的“分裂”处理。所谓“分裂”,就是把结点中处于中间位置上的关键字取出来并插入其父结点中,然后以该关键字为分界线,把原结点分成两个结点。“分裂”过程可能会一直持续到树根,若树根结点也需要分裂,则整棵树的高度增1。

例如,在图5-1所示的B树中插入关键字25时,需将其插入结点e中,由于e中已经有3个关键字,因此将关键字24插入结点e的父结点b,并以24为分界线将结点e分裂为e1和e2两个结点,结果如图5-2所示。

图5-2在图5-1所示的4阶B树中插入关键字25后的B树

函数Isgrowing(BTreeNode*root,ElemKeyTypeakey)的功能是:判断在给定的M阶B树中插入关键字akey后,该B树的高度是否增加,若增加则返回TRUE,否则返回FALSE。其中,root是指向该M阶B树根结点的指针。

在函数Isgrowing中,首先调用函数SearchBtree(即函数5-1)查找关键字akey是否在给定的M阶B树中,若在则返回FALSE(表明无需插入关键字akey,树的高度不会增加);否则,通过判断结点中关键字的数目考察插入关键字akey后该B树的高度是否增加。

【函数5-2】

boolIsgrowing(BTreeNode*root,ElemKeyTypeakey)

{BTreeNode*t,*f;

if(!SearchBtree((4))){

t=f;

while((5)){

t=t->parent;

if(!t)

试题六(15分)

阅读下列说明、图和C++代码,将应填入(n)处的字句写在答题纸的对应栏内。

某订单管理系统的部分UML类图如图6-1所示。

图6-1订单管理系统的部分UML类图

图6-1中,Product表示产品,ProductList表示产品目录,Order表示产品订单,OrderItem表示产品订单中的一个条目,OrderList表示订单列表,SalesSystem提供订单管理系统的操作接口。

请完善类Order的成员函数getOrderedAmount()和类SalesSystem的statistic()方法,各个类的属性及部分方法定义参见下面的C++代码。

【C++代码】

classProduct{//产品类

private:

stringpid;//产品识别码

stringdescription;//产品描述

doubleprice;//产品单价

public:

voidsetProductPrice(doubleprice);//设置产品单价

stringgetProductId();//获取产品识别码

stringgetProductDescription();//获取产品描述

doublegetProductPrice();//获取产品单价

//其他成员省略

};

classProductList{//产品列表类

vectorproducts;

ProductList();

ProductgetProductByIndex(inti);//获得产品列表中的第i件产品

voidaddProduct(Productt);//在产品列表中加入一件产品

Product*getProductByID(stringpid);//获得识别码为pid的产品指针

unsignedintgetProductAmount();//获得产品列表中的产品数量

classOrderItem{//订单条目类

Product*productPtr;//指向被定购产品的指针

intquantity;//定购数量

OrderItem(Product*,int);

Product*getProductptr();//获取指向被定购产品的指针

intgetQuantity();//获取被定购产品的数量

classOrder{//订单类

unsignedintorderid;//订单识别号

vectoritems;//订单内容(订单项)

Order(unsignedintorderid);

//获得识别码为tid的产品在当前订单中被定购的数量

intgetOrderedAmount(stringtid);

voidadditem(Product*productPtr,unsignedintn);//在订单中增加一个订单项

classOrderList{//订单列表类

vectororders;

OrderList();

//Begin()返回指向订单列表第一个元素的迭代器(指针)

virtualvector::iteratorOrderList::Begin();

//End()返回指向订单列表最后一个元素之后的迭代器(指向一个不存在的元素)

virtualvector::iteratorOrderList::End();

voidaddOrder(Ordert);//在订单列表中加入一份订单

classSalesSystem{

ProductListcatalog;//产品目录

OrderListsales;//订单列表

SalesSystem();

voidstatistic();//统计所有产品的定购情况

//在订单中查找识别码为tid的产品的定购数量,若该产品没有被定购,则返回0

intOrder::getOrderedAmount(stringtid)

{for(intk=0;k

if((1)==tid)

return(2);

return0;

//方法statistic()依次统计产品目录中每个产品的订购总量,并打印输出

//每个产品的识别码、描述、订购总量和订购金额

voidSalesSystem::statistic()

{unsignedintk,t,ordered_qty=0;

vector::iteratorit;Productp;

cout<<"产品识别码\t描述\t\t定购数量\t金额"<

for(k=0;k

p=(3);//从产品列表取得一件产品信息存入变量p

ordered_qty=0;

//通过迭代器变量it遍历订单列表中的每一份订单

for(it=sales.Begin();(4);it++){

//根据产品识别码获得产品p在当前订单中被定购的数量

t=(5)(p.getProductId());

ordered_qty+=t;

cout<

cout<

试题七(15分)

阅读下列说明、图以及Java程序,将应填入(n)处的字句写在答题纸的对应栏内。

某订单管理系统的部分UML类图如图7-1所示。

图7-1订单管理系统的部分UML类图

图7-1中,Product表示产品,ProductList表示所销售产品的列表,Order表示产品订单,OrderItem表示产品订单中的一个条目,OrderList表示订单列表,SalesSystem提供订单管理系统的操作接口。各个类的部分属性和方法说明如表7-1所示。

表7-1

成员

ProductList

ArrayListproducts

Product

Stringcode

产品编号

Stringdescription

产品描述

doubleprice

产品单价

Booleanequals(Objectobject)

若两个产品相同则返回true,否则返回false

OrderItem

Productproduct

订单项中的产品

intquantity

产品的订购数量

ProductgetProduct()

获取订单项中的产品

Order

ArrayListitems

订单中包含的订单项

OrderList

ArrayListorders

订单

voidaddOrder(Orderorder)

向订单列表中添加新订单

intgetNumberOfOrders()

获取订单列表中的订单总数

SalesSystem

ProductListcatalog

产品目录

OrderListsales

订单列表

voidstatistic()

依次统计产品目录中每个产品的订购总量,并打印出每个产品的编号、说明、订购总量和订购金额

可以使用类java.util.ArrayList来实现对象的聚集关系,如图7-1中OrderList与Order之间的聚集关系。

for-each循环提供了一种遍历对象集合的简单方法。在for-each循环中,可以指定需要遍历的对象集合以及用来接收集合中每个元素的变量,其语法如下:

for(用来接收集合中元素的变量:需要遍历的对象集合)

如果要使用for-each循环来遍历对象集合,那么包含该对象集合的类必须实现接口java.util.Iterable

Java程序7-1和Java程序7-2分别给出了类OrderList和方法statistic的Java代码。

【Java程序7-1】

importjava.util.*;

publicclassOrderList(1){

privateArrayListorders;

publicOrderList(){

this.orders=newArrayList();

publicvoidaddOrder(Orderorder){

this.orders.add(order);

publicIteratoriterator(){

publicintgetNumberOfOrders(){

returnthis.orders.size();

【Java程序7-2】

publicclassSalesSystem{

privateProductListcatalog;

privateOrderListsales;

privatestaticPrintWriterstdOut=newPrintWriter(System.out,true);

THE END
1.ChatGPT生成测试用例的最佳实践——用ChatGPT做软件测试(3)ChatGPT根据业务用例UC-01补充了测试用例,这使得测试用例在操作流程的使用场景方面覆盖得更加全面。 4)用例评审和改进:对测试用例的评审和改进是确保软件质量的关键环节。结合前面ChatGPT生成的功能和安全测试用例,进行测试团队内部测试用例评审,在进行内部评审时,测试团队成员发现以下问题。 http://www.51testing.com/mobile/view.php?itemid=7803832
2.ChatGPT生成测试用例的最佳实践(一)dayuhome的技术博客前面介绍的案例主要展示了ChatGPT在功能、安全和性能测试用例生成方面的应用和成果。通过ChatGPT生成测试用例,测试团队不仅可以提升工作效率,还可以加快测试工作的速度,尽早发现被测系统中的问题。问题及早发现有助于提高软件的质量和用户满意度。 ChatGPT在功能、安全和性能测试用例生成方面的应用为我们提供了一种创新的https://blog.51cto.com/u_13542393/12830699
3.软件测试22种测试方法与详解慧乐课堂软件测试 黑盒测试: 不基于内部设计和代码的任何知识,而是基于需求和功能性。 白盒测试: 白盒测试:基于一个应用代码的内部逻辑知识,测试是基于覆盖全部代码、分支、路径、条件。 单元测试: 最微小规模的测试;以测试某个功能或代码块。典型地由程序员而非测试员来做,因为它需要知道内部程序设计和编码的细https://zhuanlan.zhihu.com/p/547061772
4.软件项目测试文档大全软件测试方案,测试计划,测试报告,测试4.2.2. 软件环境 4.3. 进度安排 5. 功能测试 5.9. 网站集约化平台 6. 性能测试 6.1. 负载测试 6.2. 容量场景测试 7. 安全性与访问控制测试 8. 测试通过标准 (1) 测试用例:测试工程师根据《用户需求说明书》编写出来模拟系统所有功能的正确操作、错误操作的一系列操作说明,确保系统在任何操作前提下都能得出预https://www.bilibili.com/read/cv39886311
5.软件测试实战案例分析软件测试案例本文通过三个实际案例探讨了软件测试在电商平台支付功能、移动应用兼容性以及企业级管理系统性能中的应用,强调了细致的测试设计、严谨的执行和团队协作的重要性,展示了软件测试在提升产品质量和用户体验中的核心价值。 摘要由CSDN通过智能技术生成 **软件测试实战案例分析** https://blog.csdn.net/qq_24205027/article/details/137009763
6.大量LabVIEW的经典例程labview实例100例课程资源LabVIEW 黑白棋程序+制作教程、电梯实例、俄罗斯方块实例、员工管理系统 LabVIEW 黑白棋程序+制作教程、电梯实例、俄罗斯方块实例、员工管理系统点赞(0) 踩踩(0) 反馈 所需:3 积分 电信网络下载 文献综述.docx 2024-12-03 17:20:51 积分:1 Suno AI 是一款免费的 AI 音乐生成工具 2024-12-03 17:19:18 https://www.coder100.com/index/index/content/id/2261592
7.测试工程师校招面试考点汇总(附面试题和答案)牛客网请你说一说web测试和app测试的不同点 请问你了解什么测试方法 请问黑盒测试和白盒测试有哪些方法 请问你怎么看待测试,知道哪些测试的类型,有用过哪些测试方法? 请问你怎么测试网络协议 请你回答一下什么是α测试和β测试,以及什么时候用到他们 二、软件测试实例 https://hr.nowcoder.com/article/1334
8.100G以太网光口的FPGA测试实例腾讯云开发者社区100G以太网光口的FPGA测试实例 100G光口测试采用C50测试仪和Xilinx的VCU118开发板测试,经过测试发现,Xilinx自带的100G IP核仍然无法跑到满速,跟10G一样,也是只跑到99%的负载率。另外,工具的版本和License的申请都需要特别留意。欢迎感兴趣的同学们留言讨论。https://cloud.tencent.com/developer/article/1664963
9.软件测试——测试用例设计报告简介:软件测试 —— 测试用例设计报告 一、流程1:注册→登录 图1:注册->登录流程图 1、 使用场景设计法设计测试用例 1) 找出基本流和备选流 2) 生成相应场景 3) 画出事件流图 图2:注册->登录事件流图 4) 根据场景设计测试用例矩阵 显示详细信息 https://developer.aliyun.com/article/1507671
10.软件测试实验4黑盒测试用例设计(二)软件测试用例设计方法(二) 目录 测试用例设计之正交试验法 一、正交试验法定义 二、正交试验法设计步骤 三、实例演示 四、正交试验法的优点和不足 测试用例设计之功能图法 一、功能图法的定义 二、从功能图生成测试用例的方法 三、状态迁移图的步骤 四、实例之MP3播放功能 测试用例设计之场景法 一、场景法的定义https://www.pianshen.com/article/21331183752/
11.软件测试(第2版)教案教学设计第2章黑盒测试方法法设计测试用例?使学生了解状态迁移图法,能够描述状态迁移图法的使用场景?等价类划分法概述?实例一账号合法性的等价类划分QQ?实例二三角形问题的等价类划分?实例三余额宝提现的等价类划分?边界值分析法概述?实例一账号合法性的边界值分析QQ?实例二三角形问题的边界值分析教学重点?实例三余额宝https://www.yxfsz.com/view/1731203294045507585
12.浅谈高保真飞发一体化仿真软件Kestrel降低软件开发难度与风险的启示:一是在架构设计上应采用松耦合、 高灵活性的架构 ;二是采用 “敏捷开发”的思路,用“小步快跑” 的方式渐进发展软件,在确保原有功能的同时逐步添加新功能,推动软件的持续健康发展;三是引入配置管理、持续集成、持续测试等软件工程方法,特别是搭建基于超算的自动化测试系统确保软件质量和https://www.aerospacepower.cn/article/1060
13.软件测试PPT完整全套教学课件.pptx软件测试原则·软件测试基本流程·软件概述·软件缺陷管理·软件测试概述第1章软件测试基础第2章黑盒测试第3章白盒测试第4章性能测试第5章安全测试第6章自动化测试第7章移动App测试第8章在线考试系统(上)第9章在线考试系统(下)1.1.1软件生命周期软件生命周期可分为6个阶段:问题定义需求分析软件设计软件开发软件测试https://m.renrendoc.com/paper/276174118.html
14.软件测试工程师笔试题(互联网)工单派单功能,派单员A指派一个工单给组长B,组长认领后工单后,还可以转派给组员C,组长B和组员C都可以认领或拒绝工单任务,请设想尽可能多的路径对此功能设计测试用例, 每个用例包括测试步骤和预期结果。 *8. 数据库使用实例: 业务系统的mysql数据库有一张员工表 employees: https://www.wjx.cn/jq/113183420.aspx
15.一套比较完整的软件测试人员笔试题你为什么选择软件测试行业 因为之前有了解软件测试这个行业,觉得他的发展前景很好。 根据你以前的工作经验描述一下软件开发、测试过程,由那些角色负责,你做什么 要有架构师、开发经理、测试经理、程序员、测试员 我在里面主要是负责所分到的模块执行测试用例。 https://www.yjbys.com/bishi/timu/886502.html
16.软件测试心得体会(精选17篇)当我们经过反思,对生活有了新的看法时,好好地写一份心得体会,这么做能够提升我们的书面表达能力。你想好怎么写心得体会了吗?下面是小编帮大家整理的软件测试心得体会,仅供参考,希望能够帮助到大家。 软件测试心得体会 1 在支付宝测试分析的角色和系统分析的角色是对应的,只不过一个是测试类的另外一个是开发类的。https://www.oh100.com/a/202304/6563826.html