【计算机类职业资格】中级软件设计师下午试题-77及答案解析.doc
《【计算机类职业资格】中级软件设计师下午试题-77及答案解析.doc》由会员分享,可在线阅读,更多相关《【计算机类职业资格】中级软件设计师下午试题-77及答案解析.doc(18页珍藏版)》请在麦多课文档分享上搜索。
1、中级软件设计师下午试题-77 及答案解析(总分:96.00,做题时间:90 分钟)一、B试题一/B(总题数:1,分数:15.00)阅读下列说明和数据流图,回答问题 1 至问题 3。 说明 图书管理系统旨在用计算机对图书进行管理,包括图书的购入、借阅、归还以及注销。管理人员可以查询某位读者、某种图书的借阅情况,还可以对当前图书借阅情况进行一些统计,给出统计表格,以便掌握图书的流通情况。 系统要实现以下四方面的功能:购入新书、读者借书、读者还书以及图书注销。 (1)购入新书:需要为该书编制图书卡片,包括分类目录号、图书流水号(要保证每本书都有唯一的流水号,即使同类图书也是如此)、书名、作者、内容摘
2、要、价格和购书日期等信息,写入图书目录文件中。 (2)读者借书:填写借书单,包括读者号、欲借图书分类目录号,系统首先检查该读者号是否有效,若无效,则拒绝借书,否则进一步检查该读者所借图书是否超过最大限制数,若已达到最大借阅数,则拒绝借书,否则读者可以借出该书,登记图书分类目录号、图书流水号、读者号和借阅日期等,写回到借书文件中去。 (3)读者还书:根据图书流水号,从借书文件中读出和该图书相关的借阅记录,表明还书日期,再写回借书文件中;如果图书逾期未还,则处以相应罚款。 (4)图书注销:将一些过时或无保留价值的图书注销,从图书文件中删除相关记录。 (5)流通查询:管理员可以对图书流通情况进行查询
3、,包括某位读者、某种图书和全局图书,给出流通情况统计表。 以下是经分析得到的数据流图及部分数据字典,有些地方有待填充,假定顶层数据流图是正确的。图 1-1是顶层数据流图,图 1-2 是第 0 层数据流图,图 1-3 是第 1 层数据流图。图 1-1 图 1-2 图 1-3 数据字典 (1)数据流条目图书管理要求=入库单|借书单|还书单|注销单 入库单=分类目录号+数量+书名+作者+内容摘要+价格+购书日期 借书单=读者号+U(d)/U+借阅日期 还书单=U(e)/U+还书日期 (2)文件说明 文件名:目录文件 组成:分类目录号+书名+作者+内容摘要+价格+入库日期+总数+库存数+U(f)/U
4、(分数:15.00)(1).根据题意,指出数据流图中缺失的数据流(a)的名称,并指出该数据流的起点。 (分数:5.00)_(2).将下述文件正确填充在数据流图(b)、(c)处:读者文件、借书文件。 (分数:5.00)_(3).根据题意,补充数据字典中(d)、(e)、(f)处的空缺。 (分数:5.00)_二、B试题二/B(总题数:3,分数:15.00)1.根据 E-R 图中给出的词汇,按照“有关模式名(属性,属性,)”的格式,将此 E-R 图转换为 3 个关系模式,指出每个关系模式中的主码和外码,其中模式名根据需要取实体名或联系名。(分数:6.00)_2.创建 Athlete 表时,ANo 使用
5、 CHAR(6)并且唯一,AName 使用 CHAR(20),ASex 使用 CHAR(1),ATeam 使用 CHAR(20)。请在下列用于创建表 Athelete 的 SQL 语句空缺处填入正确的内容。 CREATE TABLE Athlete(ANo CHAR(6) NOT NULL, AName CHAR(20), ASex CHAR(1), ATeam CHAR(20) NOT NULL, _);(分数:3.00)填空项 1:_假定 Games 表存储参赛情况,如下的 SQL 语句是委员会用于查询“队名为China的各个运动员各自夺取得的总积分”的不完整语句,请在空缺处填入正确的内容
6、。 SEl3ECTU (1) /UFROM Games WHERE ANoU (2) /U(SELECT ANo FROMU (3) /UWHERE ATeam=“China“) GROUP BY ANo; (分数:6.00)(1).(分数:2.00)填空项 1:_填空项 1:_三、B试题三/B(总题数:1,分数:15.00)阅读下列说明和图,回答问题 1 至问题 3。 说明 某大型旅店为了便于管理,欲开发一个客房管理系统。希望实现客房预定、入住登记、帐务结算、退房,以及将服务项目记入客人帐单。 旅客包括散客和团体,散客预定或入住时需要提供姓名、性别、身份证和联系电话,团体则提供团体名称、负责
7、人的姓名、性别、身份证和联系电话,以及团体人数。对于散客,还要提供换房。 旅店还提供了很多服务项目,比如早餐。对每一个入住客人,服务列表记录了住宿期间的各项服务,包括服务类型、日期、数量等。当然,客人也可以不要任何服务。 旅店的客房有一个唯一的房间号,分为不同的类别,不同的房间床位数和价格不同。 为了有效的管理,需要记录每天的客房状态。客房的状态有:空闲、占用、已预定和维修。 客人入住后,客房处于占用状态; 客人退房后,客房处于空闲状态; 客人预定后,客房处于已预定状态; 预定客人入住后,客房处于占用状态; 预定客人取消预定后客房处于空闲状态; 需要维修时客房处于维修状态; 维修完成后客房处于
8、空闲状态。 该系统采用面向对象方法开发,系统中的类以及类之间的关系用 UML 类图表示,图 3-1 是该系统的类图的一部分,图 3-2 描述了客房状态的转变情况。 图 3-1 图 3-2 (分数:15.00)(1).请用图 3-1 的属性和方法的名称给出客人类的属性和方法。(注意:团体类中的负责人姓名等与散客的对应属性含义相同,不必区分) (分数:5.00)_(2).在 UML 中,重复度(Multiplicity)定义了某个类的一个实例可以与另一个类的多少个实例相关联。通常把它写成一个表示取值范围的表达式或者一个具体的值。例如图 3-1 中的类客人和住宿,客人端的“1”表示:一个住宿类的实例
9、只能与一个 1 个客人类的实例相关联;住宿类端的“0*表示:一个住宿类的实例可以与 0 个或多个客人类的实例相关。请指出图 3-1 中U(1)/U到U(4)/U处的重复度分别为多少? (分数:5.00)_(3).根据题意,请指出图 3-2 中状态 A、B 分别是什么状态,事件 C、D 分别是什么事件。 (分数:5.00)_四、B试题四/B(总题数:1,分数:6.00)阅读下列说明和图,回答问题 1 到问题 3。 说明 目前大多数操作系统都采用虚拟存储技术,这样可在较小的可用内存中执行较大的用户程序,可在内存中容纳更多程序并发执行。 引入虚拟存储技术,其基本思想是利用大容量的外存来扩充内存,产生
10、一个比有限的实际空间大得多、逻辑的虚拟内存空间,以便能够有效地支持多道程序系统的实现和大型程序运行的需要,从而增强系统的处理能力。 虚拟存储技术主要分为虚拟页式存储管理和虚拟段式存储管理。 虚拟页式存储管理中,在进程开始运行之前,不是装入全部页面,而是装入一个或零个页面之后根据进程运行的需要,动态装入其他页面:当内存空间已满,而又需要装入新的页面时,则根据某种算法淘汰某个页面,以便装入新的页面。在简单页式存储管理的基础上,增加请求调页和页面置换功能。 使用虚拟页式存储管理时需要在页表中增加以下内容:页号、驻留号、内存块号、外存地址、访问位、修改位。其中,驻留位,又称中断位,表示该页是在内存还是
11、在外存;访问位表示该页在内存期间是否被访问过;修改位表示该页在内存中是否被修改过。访问位和修改位可以用来决定置换哪个页面,具体由页面置换算法决定。 执行指令时,计算页号与页内地址,判断“该页在内存吗”,若在,则进行地址映射过程;若不在内存,则产生缺页中断。当发生缺页中断时,保存当前进程现场,判断“有空闲页面吗”,如有,直接调入所需的页面。若没有,按照某种算法选择一页置换,判断“该页被修改过吗”,如果被修改过,就必须把它写回磁盘以便更新该页在磁盘上的副本;如果该页没有被修改过,那么它在磁盘上的副本已经是最新的了,则不需要写回,调入的所需的页面直接覆盖被淘汰的页。调整页表及内存分配表,恢复被中断进
12、程现场。 补充缺页中断处理流程图 4-1 中的判断(1)(3)。 图 4-1 (分数:6.00)(1).(分数:1.20)填空项 1:_填空项 1:_五、B试题五/B(总题数:1,分数:15.00)阅读下列函数说明和 C 代码,将应填入U (n) /U处的字句写上。 说明 若要在 N 个城市之间建立通信网络,只需要 N-1 条线路即可。如何以最低的经济代价建设这个网络,是一个网的最小生成树的问题。现要在 8 个城市间建立通信网络,其问拓扑结构如图 5-1 所示,边表示城市间通信线路,边上标示的是建立该线路的代价。 图 5-1 无向图用邻接矩阵存储,元素的值为对应的权值。考虑到邻接矩阵是对称的且
13、对角线上元素均为 0,故压缩存储,只存储上三角元素(不包括对角线)。 现用 Prim 算法生成网络的最小生成树。由网络 G=(V,E)构造最小生成树 T=(U,TE)的 Prim 算法的基本思想是:首先从集合 V 中任取一顶点放入集合 U 中,然后把所有一个顶点在集合 U 里、另一个顶点在集合V-U 里的边中,找出权值最小的边(u,v),将边加入 TE,并将顶点 v 加入集合 U,重复上述操作直到 U=V为止。 函数中使用的预定义符号如下: #define MAX 32768 /*无穷大权,表示顶点间不连通*/ #define MAXVEX 30 /*图中顶点数目的最大值*/ typedef
14、struct int startVex,stopVex; /*边的起点和终点*/ float weight; /*边的权*/ Edge; typedef struct char vexsMAXVEX; /*顶点信息*/ float arcsMAXVEX*(MAXVEX-1)/2; /*邻接矩阵信息,压缩存储*/ int n; /*图的顶点个数*/ Graph; 函数 void PrimMST(Graph*pGraph, Edge mst) int i,j,k,min,vx,vy; float weight,minWeight; Edge edge; for(i=0; ipGraph-n-1;i
15、+) msti.StartVex=0; msti.StopVex=i+1; msti.weight=pGraph-arcsi; for(i=0;iU(1)/U;i+)/*共 n-1 条边*/ minWeight=(float)MAX; min=i; /*从所有边(vx,vy)中选出最短的边*/ for(j=i; jpGraph-n-1; j+) if(mstj.weightminWeight) minWeight=U(2)/U; min=j; /*mstminl 是最短的边(vx,vy),将 mstmin加入最小生成树*/ edge=mstmin; mstmin=msti; msti=edge
16、; vx=U (3) /U;/*vx 为刚加入最小生成树的顶点下标*/ /*调整 msti+1到 mstn-1*/ for(j=i+1;jpGraph-n-1;j+) vy=mstj.StopVex; if(U (4) /U)/*计算(vx,vy)对应的边在压缩矩阵中的下标*/ k=pGraph-n*vy-vy*(vy+1)/2+vx-vy-1; else k=pGraph-n*vx-vx*(vx+1)/2+vy-vx-1; weight=U (5) /U; if(weightmstj.weight) mstj.weight=weight; mstj.StartVex=vx; (分数:15.0
17、0)(1).(分数:3.00)填空项 1:_填空项 1:_填空项 1:_填空项 1:_六、B试题六/B(总题数:1,分数:15.00)阅读以下说明和 C+代码,将应填入U (n) /U处的字句写上。 说明 现有一个显示系统,要显示的图形有线 Line、矩形 Square,抽象出一个 Shape 类(接口),有方法显不display()。 需要新增图形 Circle,又已知有类 XXCircle 实现了所需要实现的功能:显示 displayIt()。为了继承自shape 以提供统一接口,又不希望从头开发代码,希望使用 XXCircle。这样将 XXcircle 作为 Circle 的一个属性,即
18、 Circle 的对象包含一个 XXCircle 对象。当一个 Circle 对象被实例化时,它必须实例化一个相应的 XXCircle 对象: Circle 对象收到的做任何事的请求都将转发给这个 XXCircle 对象。通过这种称为 Adapter 模式,Circle 对象就可以通过“让 XXCircle 做实际工作”来表现自己的行为了。图 6-1 显示了各个类间的关系。以下是 C+语言实现,能够正确编译通过。 图 6-1 C+代码 class Shape public: U (1) /Uvoid display()=0; ; class Line:public Shape/省略具体实现 ;
19、 class Square:public Shape/省略具体实现 ; class XXCircle public: void displayIt() /省略具体实现 /省略其余方法和属性 ; class Circle:public Shape private: XXCircle *pxc; public: Circle(); void display(); ; Circle:Circle() pxc=U (2) /U; void Circle:display() pxc-U (3) /U; class Factory public: U (4) /UgetshapeInstance(int
20、type)/生成特定类实例 switch(type) case 1:return new Square; case 2:return new Line;case 3 :return new Circle; default:return NULL; ; void main(int argc,char*argv) if(argc !=2) cout“error parameters!“endl; return; int type=atoi(argv1); Factory factory; Shape*s=factory.U (5) /U; if(s=NULL) cout“Error get the
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
5000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 职业资格 中级 软件 设计师 下午 试题 77 答案 解析 DOC
