软件设计师考试历年试题Word文档格式.docx

上传人:b****0 文档编号:13238443 上传时间:2022-10-08 格式:DOCX 页数:17 大小:401.58KB
下载 相关 举报
软件设计师考试历年试题Word文档格式.docx_第1页
第1页 / 共17页
软件设计师考试历年试题Word文档格式.docx_第2页
第2页 / 共17页
软件设计师考试历年试题Word文档格式.docx_第3页
第3页 / 共17页
软件设计师考试历年试题Word文档格式.docx_第4页
第4页 / 共17页
软件设计师考试历年试题Word文档格式.docx_第5页
第5页 / 共17页
点击查看更多>>
下载资源
资源描述

软件设计师考试历年试题Word文档格式.docx

《软件设计师考试历年试题Word文档格式.docx》由会员分享,可在线阅读,更多相关《软件设计师考试历年试题Word文档格式.docx(17页珍藏版)》请在冰豆网上搜索。

软件设计师考试历年试题Word文档格式.docx

起点

终点

补充的数据流

试题二(共15分)

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

某集团公司拥有多个大型连锁商场,公司需要构建一个数据库系统以方便管理其业务运作活动。

【需求分析结果】

1.商场需要记录的信息包括商场编号(编号唯一),商场名称,地址和联系电话。

某商场信息如表2-1所示。

表2-1商场信息表

商场编号

商场名称

地址

联系电话

PS2101

淮海商场

淮海中路918号

021-

PS2902

西大街商场

西大街时代盛典大厦

029-

PS2903

东大街商场

碑林区东大街239号

PS2901

长安商场

雁塔区长安中路38号

2.每个商场包含有不同的部门,部门需要记录的信息包括部门编号(集团公司分配),部门名称,位置分布和联系电话。

某商场的部门信息如表2-2所示。

表2-2部门信息表

部门编号

部门名称

位置分布

DT002

财务部

商场大楼六层

DT007

后勤部

商场地下副一层

DT021

安保部

DT005

人事部

DT001

管理部

商场裙楼三层

3.每个部门雇用多名员工处理日常事务,每名员工只能隶属于一个部门(新进员工在培训期不隶属于任何部门)。

员工需要记录的信息包括员工编号(集团公司分配),姓名,岗位,电话号码和工资。

员工信息如表2-3所示。

 

表2-3员工信息表

员工编号

姓名

岗位

电话号码

工资

XA3310

周超

理货员

1500.00

SH1075

刘飞

防损员

XA0048

江雪花

广播员

1428.00

BJ3123

张正华

部门主管

1876.00

4.每个部门的员工中有一名是经理,每个经理只能管理一个部门,系统需要记录每个经理的任职时间。

【概念模型设计】

根据需求阶段收集的信息,设计的实体联系图和关系模式(不完整)如下:

图2-1实体联系图

【关系模式设计】

商场(商场编号,商场名称,地址,联系电话)

部门(部门编号,部门名称,位置分布,联系电话,(a))

员工(员工编号,员工姓名,岗位,电话号码,工资,(b))

经理((c),任职时间)

(6分)

根据问题描述,补充四个联系,完善图2-1的实体联系图。

联系名可用联系1、联系2、联系3和联系4代替,联系的类型分为1:

1、1:

n和m:

n。

根据实体联系图,将关系模式中的空(a)~(c)补充完整,并分别给出部门、员工和经理关系模式的主键和外键。

【问题3】

(3分)

为了使商场有紧急事务时能联系到轮休的员工,要求每位员工必须且只能登记一位紧急联系人的姓名和联系电话,不同的员工可以登记相同的紧急联系人。

则在图2-1中还需添加的实体是

(1),该实体和图2-1中的员工存在

(2)联系(填写联系类型)。

给出该实体的关系模式。

试题三(共15分)

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

某银行计划开发一个自动存提款机模拟系统(ATMSystem)。

系统通过读卡器CardReader)读取ATM卡;

系统与客户(Customer)的交互由客户控制台(CustomerConsole)实现;

银行操作员(Operator)可控制系统的启动(SystemStartup)和停止(SystemShutdown);

系统通过网络和银行系统(Bank)实现通信。

当读卡器判断用户已将ATM卡插入后,创建会话(Session)。

会话开始后,读卡器进行读卡,并要求客户输入个人验证码(PIN)。

系统将卡号和个人验证码信息送到银行系统进行验证。

验证通过后,客户可从菜单选择如下事务(Transaction):

1.从ATM卡账户取款(Withdraw);

2.向ATM卡账户存款(Deposit);

3.进行转账(Transfer);

4.查询(Inquire)ATM卡账户信息。

一次会话可以包含多个事务,每个事务处理也会将卡号和个人验证码信息送到银行系统进行验证。

若个人验证码错误,则转个人验证码错误处理(InvalidPINProcess)。

每个事务完成后,客户可选择继续上述事务或退卡。

选择退卡时,系统弹出ATM卡,会话结束。

系统采用面向对象方法开发,使用UML进行建模。

系统的顶层用例图如图3-1所示,一次会话的序列图(不考虑验证)如图3-2所示。

消息名称参见表3-1。

表3-1可能的消息名称列表

名称

说明

cardInserted()

ATM卡已插入

performTransaction()

执行事务

performSession()

执行会话

readCard()

读卡

readPIN()

读取个人验证码

PIN

个人验证码信息

creat(atm,this,card,pin)

为当前会话创建事务

create(this)

为当前ATM创建会话

card

ATM卡信息

doAgain

执行下一个事务

ejectCard()

弹出ATM卡

根据【说明】中的描述,给出图3-1中A1和A2所对应的参与者,U1至U3所对应的用例,以及该图中空

(1)所对应的关系。

(U1至U3的可选用例包括:

Session、Transaction、InsertCard、InvalidPINProcess和Transfer)

根据【说明】中的描述,使用表3-1中的英文名称,给出图3-2中6~9对应的消息。

(2分)

解释图3-1中用例U3和用例Withdraw、Deposit等四个用例之间的关系及其内涵。

图3-1ATM系统顶层用例图

图3-2一次会话的序列图(无验证消息)

试题四(共15分)

现需在某城市中选择一个社区建一个大型超市,使该城市的其它社区到该超市的距离总和最小。

用图模型表示该城市的地图,其中顶点表示社区,边表示社区间的路线,边上的权重表示该路线的长度。

现设计一个算法来找到该大型超市的最佳位置:

即在给定图中选择一个顶点,使该顶点到其它各顶点的最短路径之和最小。

算法首先需要求出每个顶点到其它任一顶点的最短路径,即需要计算任意两个顶点之间的最短路径;

然后对每个顶点,计算其它各顶点到该顶点的最短路径之和;

最后,选择最短路径之和最小的顶点作为建大型超市的最佳位置。

(12分)

本题采用Floyd-Warshall算法求解任意两个顶点之间的最短路径。

已知图G的顶点集合为V={1,2,...,},

W={wij}*为权重矩阵。

为从顶点i到顶点j的一条最短路径的权重。

当k=0时,不存在中间顶点,因此

=wij;

当k>

0时,该最短路径上所有的中间顶点均属于集合{1,2,...,}。

若中间顶点包括顶点k,则

=

+

若中间顶点不包括顶点k,则

于是得到如下递归式。

因为对于任意路径,所有的中间顶点都在集合{1,2,...,}内,因此矩阵D(n)={

}n*n给出了任意两个顶点之间的最短路径,即对所有i,j∈V,

表示顶点i到顶点j的最短路径。

下面是求解该问题的伪代码,请填充其中空缺的

(1)至(6)处。

伪代码中的主要变量说明如下:

W:

权重矩阵

n:

图的顶点个数

SP:

最短路径权重之和数组,SP[i]表示顶点i到其它各顶点的最短路径权重之和,i从1到n

min_SP:

最小的最短路径权重之和

min_v:

具有最小的最短路径权重之和的顶点

i:

循环控制变量

j:

k:

LOCATE-SHOPPINGMALL(W,n)

1D(0)=W

2for

(1)

3fori=1ton

4forj=1ton

5if

6

(2)

7else

8(3)

9fori=1ton

10SP[i]=0

11forj=1ton

12(4)

13min_SP=SP[1]

14(5)

15fori=2ton

16ifmin_SP>

SP[i]

17min_SP=SP[i]

18min_v=i

19return(6)

【问题1】中伪代码的时间复杂度为(7)(用Ο符号表示)。

试题五(共15分)

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

【说明】

对二叉树进行遍历是二叉树的一个基本运算。

遍历是指按某种策略访问二叉树的每个结点,且每个结点仅访问一次的过程。

函数InOrder()借助栈实现二叉树的非递归中序遍历运算。

设二叉树采用二叉链表存储,结点类型定义如下:

typedefstructBtNode{

ElemTypedata;

/*结点的数据域,ElemType的具体定义省略*/

structBtNode*lchild,*rchild;

/*结点的左、右孩子指针域*/

}BtNode,*BTree;

在函数In

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

当前位置:首页 > 初中教育

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

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