1、上半年软件设计师下午试题及答案 全国计算机技术与软件专业技术资格(水平)考试2009年上半年软件设计师下午试卷 试题一 阅读下列说明,回答问题1和问题2,将解答填入答题纸的对应栏内。 说明 假设某大型商业企业由商品配送中心和连锁超市组成,其中商品配送中心包括采购、财务、配送等部门。为实现高效管理,设计了商品配送中心信息管理系统,其主要功能描述如下: 1系统接收由连锁超市提出的供货请求,并将其记录到供货请求记录文件。 2在接到供货请求后,从商品库存记录文件中进行商品库存信息查询。如果库存满足供货请求,则给配送处理发送配送通知:否则,向采购部门发出缺货通知。 3配送处理接到配送通知后,查询供货请求
2、记录文件,更新商品库存记录文件,并向配送部门发送配送单,在配送货品的同时记录配送信息至商品配送记录文件。 4采购部门接到缺货通知后,与供货商洽谈,进行商品采购处理,合格商品入库,并记录采购清单至采购清单记录文件、向配送处理发出配送通知,同时通知财务部门给供货商支付货款。 该系统采用结构化方法进行开发,得到待修改的数据流图如下图所示。 问题1使用说明中的词语,给出上图中外部实体E1至E4的名称和数据存储D1至D4的名称。答:E1:财务部门 E2:采购部门 E3:连锁超市 E4:配送部门 D1:采购清单记录文件 D2:商品库存记录文件 D3:商品配送记录文件 D4:供货请求记录文件 问题2以上数据
3、流图中存在四处错误数据流,请指出各自的起点和终点;若将上述四条错误数据流删除,为保证数据流图的正确性,应补充三条数据流,请给出所补充数据流的起点和终点。(起点和终点请采用上述数据流图中的符号或名称)答: 错误数据流 补充的数据流 试题一分析 本题考查DFD的分析与设计,问题一主要考查DFD中的外部实体和数据存储,由于在题干中已经提到“系统接收由连锁超市提出的供货请求,并将其记录到供货请求记录文件”,因此可以明确出“连锁超市”外部实体和“供货请求记录文件”数据存储:对应到DFD图中为E3和D4。描述中的第二项提出“从商品库存记录文件中进行商品库存信息查询。如果库存满足供货请求,则给配送处发送配送
4、通知;否则,向采购部门发出缺货通知”,因为配送通知需要发送到采购部门,因此采购部门将成为系统的外部实体;同时,商品库存记录文件能够提供库存信息,所以DFD图中E2和D2分别为采购部门和商品配送记录文件。第三项需求“配送处理接到配送通知后,查询供货请求记录文件,更新商品库存记录文件,并向配送部门发送配送单,在配送货品的同时记录配送信息至商品配送记录文件”,所以配送处理需要查询供货请求记录文件,更新商品库存记录文件与商品配送记录文件,因此D3为商品配送记录文件;采购处理需要记录采购清单同时通知财务部门,所以E1应该为财务部门,D1为采购清单记录文件,剩下的E4则为配送部门。 DFD中出现的错误数据
5、流为:E1到E2,E1与E2的数据流不属于系统的范围;D3到E4,多余的数据流;D2到采购处理,数据流方向错误;D4到供货请求处理,数据流方向错误。 需要补充的数据流为:E2到采购处理,因为E2是采购部门,采购部门需要给采购处提供入库商品信息;采购处到D2需要一条数据流,因为采购处理需要更改库存信息;供货请求处理到D4需要一条数据流,因为供货请求处理需要记录供货请求信息。 试题二 阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 说明 某集团公司拥有多个大型连锁商场,公司需要构建一个数据库系统以方便管理其业务运作活动。 需求分析结果 1商场需要记录的信息包括商场编号(编号唯一),
6、商场名称,地址和联系电话。某商场信息如下表所示。商场信息表 2每个商场包含有不同的部门,部门需要记录的信息包括部门编号(集团公司分配),部门名称,位置分布和联系电话。某商场的部门信息如下表所示。 部门信息表 3每个部门雇用多名员工处理日常事务,每名员工只能隶属于一个部门(新进员工在培训期不隶属于任何部门)。员工需要记录的信息包括员工编号(集团公司分配),姓名,岗位,电话号码和工资。员工信息如下表所示。 员工信息表 4每个部门的员工中有一名是经理,每个经理只能管理一个部门,系统需要记录每个经理的任职时间。 概念模型设计 根据需求阶段收集的信息,设计的实体联系图和关系模式(不完整)如下:实体联系图
7、 关系模式设计 商场(商场编号,商场名称,地址,联系电话) 部门(部门编号,部门名称,位置分布,联系电话, (a) ) / a: 商场编号 员工(员工编号,员工姓名,岗位,电话号码,工资, (b) ) /b:部门编号 经理( (c) ,任职时间) /c:员工编号 问题1根据问题描述,补充四个联系,完善图21的实体联系图。联系名可用联系1、联系2、联系3和联系4代替,联系的类型分为1:1、1:n和m:n。答: 问题2根据实体联系图,将关系模式中的空(a)(c)补充完整,并分别给出部门、员工和经理关系模式的主键和外键。 问题3为了使商场有紧急事务时能联系到轮休的员工,要求每位员工必须且只能登记一位
8、紧急联系人的姓名和联系电话,不同的员工可以登记相同的紧急联系人。则在图21中还需添加的实体是 (1) ,该实体和图2-1中的员工存在 (2/登记) 联系(填写联系类型)。给出该实体的关系模式。答:紧急联系人(员工编号,姓名,联系电话) 试题二分析 本题考查数据库概念结构设计及概念结构向逻辑结构转换的过程。 此类题目要求考生认真阅读题目对现实问题的描述,经过分类、聚集和概括等方法从中确定实体及其联系。题目已经给出了4个实体,需要根据需求描述给出实体间的联系。 问题1由“每个商场包含有不同的部门”可知商场与部门间为1:m联系;由“每个部门雇用了多名员工处理日常事务”可知部门与员工间为1:p联系;由
9、“每个部门的员工中有一个经理每个经理只能管理一个部门”可知部门与经理间为1:1联系,并且员工是经理的超类型,经理是员工的子类型。 问题2 商场的属性信息中,商场编号由集团公司分配,不会重复,可作为商场的主键属性;部门的属性信息中,部门编号由集团公司分配,不会重复,可作为部门的主键属性,商场与部门的联系需要通过将商场的主键(商场编号)加入到部门中来表达;员工的属性信息中,员工编号由集团公司分配,不会重复,可作为员工的主键属性,部门与员工的联系需要通过将部门的主键(部门编号)加入到员工中来表达;经理除了包含员工的属性信息外,还需要任职时间属性。完整的关系模式如下: 商场(商场编号,商场名称,地址,
10、联系电话) 部门(部门编号,部门名称,位置分布,联系电话,商场编号) 员工(员工编号,姓名,岗位,电话号码,工资,部门编号) 经理(员工编号,任职时间) 问题3 员工的紧急联系人信息通过添加紧急联系人关系来实现,由“每位员工必须且只能登记一位紧急联系人的姓名和联系电话”,但可能存在多位员工登记同一位家属,可知员工与家属间为n:1联系:由“不同员工可以登记相同的紧急联系人”可知,员工编号可作为家属的主键属性。所以需要添加的关系模式如下: 紧急联系人(员工编号,姓名,联系电话) 参考答案 问题1 (图中的m、n也可用*表示,对联系名称可不做要求,但不能出现重名) 问题2 (a)商场编号 (b)部门
11、编号 (c)员工编号 部门关系模式的主键:部门编号 外键:商场编号 员工关系模式的主键:员工编号 外键:部门编号 经理关系模式的主键:员工编号 外键:员工编号 问题3 (d)紧急联系人 (e)1:n 关系模式:紧急联系人(员工编号,姓名,联系电话) 试题三 阅读下列说明和图,回答问题1至问题3,将解答填入答题纸的对应栏内。 说明 某银行计划开发一个自动存提款机模拟系统(ATM System)。系统通过读卡器 (CardReader)读取ATM卡;系统与客户(Customer)的交互由客户控制台(Customer-Console)实现;银行操作员(Operator)可控制系统的启动(System
12、 Startup)和停止(System Shutdown):系统通过网络和银行系统(Bank)实现通信。 当读卡器判断用户已将ATM卡插入后,创建会话(Session)。会话开始后,读卡器进行读卡,并要求客户输入个人验证码(PIN)。系统将卡号和个人验证码信息送到银行系统进行验证。验证通过后,客户可从菜单选择如下事务(Transaction): 1从ATM卡账户取款(Withdraw); 2向ATM卡账尸存款(Deposit); 3进行转账(Transfer): 4查询(Inquire)ATM卡账户信息。 一次会话可以包含多个事务,每个事务处理也会将卡号和个人验证码信息送到银行系统进行验证。若
13、个人验证码错误,则转个人验证码错误处理(Invalid PIN Process)。每个事务完成后,客户可选择继续上述事务或退卡。选择退卡时,系统弹出ATM卡,会话结束。 系统采用面向对象方法开发,使用UML进行建模。系统的顶层用例图如图3-1所示,一次会话的序列图(不考虑验证)如图3-2所示。 问题1根据说明中的描述,给出图3-1中A1和A2所对应的参与者,U1至U3所对应的用例,以及该图中空 (1) 所对应的关系。(U1至U3的可选用例包括:Session、Transaction、Insert Card、Invalid PIN Process和Transfer)答:A1:Customer A
14、2:Bank U1:Session U2:Invalid PIN Process U3:Transaction (1):extend 问题2 根据说明中的描述,使用消息名称列表中的英文名称,给出图3-2中69对应的消息。答: 6:readPIN() 7:PIN 8:creat(atm,this,card,pin) 9:preformTransaction() 问题3 解释图3-1中用例U3和用例Withdraw、Deposit等四个用例之间的关系及其内涵。答:Transaction是一个抽象泛化用例,具有其他事务类型共有的属性和行为,每个具体的事务类型继承它,并实现适合自己的特定的操作。 试题
15、三分析 本题涉及面向对象系统开发时的UML用例图、序列图以及用例之间的关系。 问题1 构建用例图时,常用的方式是先识别参与者,然后确定用例以及用例之间的关系。 识别参与者时,考查和系统交互的人员和外部系统。本题中,与系统交互的人员包括客户(Customer)和银行操作员(Operator),与本模拟系统交互的外部系统包括银行。系统(Bank)。 考查用例时,通过判断哪一个特定参与者发起或者触发了与系统的哪些交互,宋识别用例并建立和参与者之间的关联。考查用例之间的关系时,include(包含)定义了用例之间的包含关系,用于一个用例包含另一个用例的行为的建模;如果可以从一个用例的执行中,在需要时转
16、向执行另一个用例,执行完返回之前的用例继续执行,用例间即存在extend关系。 本题中,客户一旦插卡成功,系统就创建会话(Session),会话中可以执行用户从菜单选择的Withdraw、Deposit、Transfer和Inquire等事务(Transaction)。由图中U3和 Withdraw之间的扩展关系,可知U3为Transaction;又由U1和U3之间的include关系,得知U1为Session,进而判定图中A1为Customer,A2为Bank。每个事务处理也会将卡号和个人验证码信息送到银行系统进行验证,若个人验证码错误,则转个人验证码错误处理(1nvalid PIN Pro
17、cess,图中U2),所以(1)处应填extend。 问题2 序列图是场景的图形化表示,描述了以时间顺序组织的对象之间的交互活动。构造序列图时遵循如下指导原则:确定顺序图的范围,描述这个用例场景或一个步骤;绘制参与者和接口类,如果范围包括这些内容的话:沿左手边列出用例步骤;对控制器类及必须在顺序中协作的每个实体类,基于它拥有的属性或已经分配给它的行为绘制框;为持续类和系统类绘制框;绘制所需消息,并把每条消息指到将实现响应消息的责任的类上;添加活动条指示每个对象实例的生命期;为清晰起见,添加所需的返回消息;如果需要,为循环、可选步骤和替代步骤等添加框架。 本题中,根据说明中的描述,从ATM机判断
18、卡已插入(card Inserted()开始会话,即为当前ATM创建会话(create(this)并开始执行会话(perform Session():读卡器读卡(read Card()获得ATM卡信息(card),然后从控制台读取个人验证码输入(read PIN(),图中标号6处)并获得个人验证码信息(PIN,图中标号7处):然后根据用户选择启动并执行事务,即为当前会话创建事务(creat(atm,this,card,pin),图中标号8处)和执行事务(perform Transaction(),图中标号9处):可以选择继续执行某个事务(do Again)循环,或者选择退卡(eject Car
19、d()。 问题3 用例之间的继承关系表示子类型“是一种”父类型。其中父类型通常是一个抽象泛化用例,具有子类型共有的属性和行为,每个具体的子类型继承它,并实现适合自己的特定的操作。 本题中Transaction和Withdraw、Deposit等四个用例之间的关系即为继承关系, Transaction即是一个抽象泛化用例,具有其他事务类型共有的属性和行为,每个具体的事务类型继承它,并实现适合自己的特定的操作。 参考答案 问题1 A1:Customer A2:Bank U1:Session U2:Invalid PIN Process U3:Transaction (1):extend 问题2 6
20、:read PIN() 7:PIN 8:creat(atm,this,card,pin) 9:perform Transaction() 问题3 Transaction是一个抽象泛化用例,具有其他事务类型共有的属性和行为,每个具体的事务类型继承它,并实现适合自己的特定的操作。 试题四 阅读下列说明,回答问题1和问题2,将解答填入答题纸的对应栏内。 说明 现需在某城市中选择一个社区建一个大型超市,使该城市的其他社区到该超市的距离总和最小。用图模型表示该城市的地图,其中顶点表示社区,边表示社区间的路线,边上的权重表示该路线的长度。 现设计一个算法来找到该大型超市的最佳位置:即在给定图中选择一个顶点
21、,使该顶点到其他各顶点的最短路径之和最小。算法首先需要求出每个顶点到其他任一顶点的最短路径,即需要计算任意两个顶点之间的最短路径;然后对每个顶点,计算其他各顶点到该顶点的最短路径之和;最后,选择最短路径之和最小的顶点作为建大型超市的最佳位置。 问题1 本题采用F10y-Warshall算法求解任意两个顶点之间的最短路径。已知图G的顶点集合为V=1,2,n),W=Wjj n*n。为权重矩阵。设为从顶点i到顶点j的一条最短路径的权重。当k=0时,不存在中间顶点,因此=Wij:当k0时,该最短路径上所有的中间顶点均属于集合1,2,k。若中间顶点包括顶点k,则;若中间顶点不包括顶点k,则。于是得到如下
22、递归式。 因为对于任意路径,所有的中间顶点都在集合1,2,n内,因此矩阵给出了任意两个顶点之间的最短路径,即对所有I,jV,表示顶点i到顶点j的最短路径。 下面是求解该问题的伪代码,请填充其中空缺的(1)至(6)处。伪代码中的主要变量说明如下: W:权重矩阵 n:图的顶点个数 SP:最短路径权重之和数组,SPi表示顶点i到其他各顶点的最短路径权重之和,i从1到n min_SP:最小的最短路径权重之和 min_V:具有最小的最短路径权重之和的顶点 i:循环控制变量 j:循环控制变量 k:循环控制变量 LOCATE -SHOPPINGMALL (W, n) 1 D(0) = W 2 for (1)
23、 /k = 1 to n 3 for i = 1 to n 4 for j = 1 to n 6 (2) / 7 else 8 (3) / 9 for i = 1 to n 10 SP i = 0 11 for j = 1 to n 12 (4) / SPi=SPi+ 13 min SP = SP1 14 (5) / min v=1 15 for i = 2 to n 16 if min SP SPi 17 min SP = SPi 18 min v = i 19 return (6) / min v 问题2 问题1中伪代码的时间复杂度为 (7) (用O符号表示)。/(7) O(n3) 试题四
24、分析 本题考查的是算法的设计和分析技术。 问题1 本问题考查算法流程。第(1)空表示主循环,k是循环控制变量,故第(1)空填 k=1 to n。第(2)和(3)空根据题意和递归式,可分别得到答案为)和。计算了任意两个顶点之间的最短路径之后,对每个顶点,开始统计其到所有其他顶点的最短路径之和,因此第(4)空填SPi=SPi+ 。第13和第14行初始化,假设最小的到所有其他顶点的最短路径之和为第一个顶点的最小路径之和,大型超市的最佳位置为第一个顶点,故第(5)空填min v=1。最后要求返回大型超市的最佳位置,即到所有其他顶点的最短路径之和最小的顶点,故第(6)空填min v。 问题2 本问题考查
25、问题门中的伪代码第28行,计算任意两点之间的最短路径,有三重循环,故时间复杂度为O(n3)。第912行,计算每个点到任意其他点的最短路径之和,有两重循环,故时间复杂度为O(n2)。第1518行,在所有点的最短路径之和中找到最小的最短路径之和,时间复杂度为O(n)。故算法总的时间复杂度为O(n3)。 参考答案 问题1 (1)k=1 to n (2) (3) (4) SPi=SPi+ (5)min_v=1 (6)min_v 问题2 (7) O(n3) 试题五 阅读下列说明和C函数代码,将应填入 (n) 处的字句写在答题纸的对应栏内。 说明 对二叉树进行遍历是二叉树的一个基本运算。遍历是指按某种策略
26、访问二叉树的每个节点,且每个节点仅访问一次的过程。函数InOrder()借助栈实现二叉树的非递归中序遍历运算。 设二叉树采用二叉链表存储,节点类型定义如下: typedef struct BtNode ElemType data; /*节点的数据域,ElemType的具体定义省略*/ struct BtNode * lchild * rchild; /*节点的左、右孩子指针域*/ BtNode,*BTree; 在函数InOrder()中,用栈暂存二叉树中各个节点的指针,并将栈表示为不含头节点的单向链表(简称链栈),其节点类型定义如下: typedef struct StNode /*链栈的节点
27、类型*/ BTree elem; /*栈中的元素是指向二叉链表节点的指针*/ struct StNode*link; StNode; 假设从栈顶到栈底的元素为en、en-1、e1,则不含头节点的链栈示意图如图5-1所示。 图5-1 链栈示意图 C函数 int InOrder(BTree root) /*实现二叉树的非递归中序遍历*/ BTree ptr; /*ptr用于指向二叉树中的节点*/ StNode*q; /*q暂存链栈中新创建或待删除的节点指针*/ StNode*stacktop=NULL; /*初始化空栈的栈顶指针stacktop*/ Ptr=root; /*ptr指向二叉树的根节点
28、*/ while ( (1) ptr!=NULL | | stacktop !=NULL) while (ptr!=NULL) q= (StNode*)malloc(sizeof (StNode); if (q= =NULL) return-1; q-elem=ptr; (2) q-link=stacktop ; stacktop=q; /*stacktop指向新的栈顶*/ ptr= (3) ptr-lchild ; /*进入左子树*/ q=stacktop; (4) smcktop=stacktop-link,或stacktop=q-link ; /*栈顶元素出栈*/ visit(q); /
29、*visit是访问节点的函数,其具体定义省略*/ ptr= (5)q-elem-rchild ; /*进入右子树*/ free(q); /*释放原栈顶元素的节点空间*/ return 0; /*Inorder*/ 试题五分析 本题考查基本数据结构和C语言程序设计能力。 对非空二叉树进行中序遍历的方法是:先中序遍历根节点的左子树,然后访问根节点,最后中序遍历根节点的右子树。用递归方式描述的算法如下: void In_order_Traversing (BiTree root) / / root是指向二叉树根节点的指针 if (root !=NULL) In_order_Traversing(ro
30、ot-LeftChild); visit(root); In_order_Traversing(rootRightChild); 从以上算法的执行过程可知,从树根出发进行遍历时,递归调用In_Order_Traversing(root-LeftChild)使得遍历过程沿着左孩子分支一直走向下层节点,直到到达二叉树中最左下方的节点(设为f)的空左子树为止,然后返回f节点,再由递归调用 In_Order_Traversing(root-RightChild)进入f的右子树,并重复以上过程。在递归算法执行过程中,辅助实现递归调用和返回处理的控制栈实际上起着保存从根节点到当前节点的路径信息。 用非递归算法实现二叉树的中序遍历时,可以由一个循环语句实现从指定的根节点出发,沿着左孩子分支一直到头(到达一个没有左子树的节点)的处理,从根节点到当前节点的路径信息(节点序列)可以明确构造一个栈来保存。 本题目的难点在于将栈的实现和使用混合在一起来处理,而且栈采用单链表存储结构。下面分析题中给出的代码。 空(1)是遍历的条件之一,由于另外一个条件stacktop!=ULL初始时是不成立的,因此空(1)所表示的条件必须满足,由于是对非空二叉树进行遍历,显然该条件
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1