2014年下半年软件设计师下午试题
试题:1
    阅读下列说明和图,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】
    某大型披萨加工和销售商为了有效管理生产和销售情况,欲开发一披萨信息系统,
其主要功能如下:
    1)销售。处理客户的订单信息,生成销售订单,并将其记录在销售订单表中。销售订单记录了订购者、所订购的披萨、期望的交付日期等信息。
    2)生产控制。根据销售订单以及库存的披萨数量,制定披萨生产计划(包括生产哪些披萨、生产顺序和生产量等),并将其保存在生产计划表中。
    3)生产。根据生产计划和配方表中的披萨配方,向库存发出原材料申领单,将制作好的披萨的信息存入库存表中,以便及时进行交付。
    4)采购。根据所需原材料及库存量,确定采购数量,向供应商发送采购订单,并将其记录在采购订单表中;得到供应商的供应量,将原材料数量记录在库存表中,在采购订单表中标记已完成采购的订单。
    5)运送。根据销售订单将披萨交付给客户,并记录在交付记录表中。
    6)财务管理。在披萨交付后,为客户开具费用清单,收款并出具收据;依据完成的采购订单给供应商支付原材料费用并出具支付细节;将收款和支付记录存入收支记录表中。
    7)存储。检查库存的原材料、拔萨和未完成订单,确定所需原材料。
  现采用结构化方法对披萨信息系统进行分析与设计,获得如图1-1所示的上下文数据流图和图1-2所示的0层数据流图。
1-1 上下文数据流图
1-2  0层数数据流图
【问题1】(4分)
  根据说明中的词语,给出图1-1中的实体E1E2的名称。
E1: 客户                      E2: 供应商
【问题2】(5分)
  根据说明中的词语,给出图1-2中的数据存储D1D5的名称。
D1: 销售订单表                D2: 库存表              D3: 生产计划表           
D4: 原材料申领单              D5: 采购订单表
【问题3】(6分)
  根据说明和图中词语,补充图1-2中缺失的数据流及其起点和终点。
1:数据流名称:支付细节      起点:4        终点:E2
2:数据流名称:生产计划      pushed起点:D3      终点:3
3:数据流名称:库存量        起点:7        终点:4
4:数据流名称:原材料数量    起点:4        终点:D2
5:数据流名称:交付          起点:D1      终点:5
试题:2
    阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】
    某集团公司在全国不同城市拥有多个大型超市,为了有效管理各个超市的业务工作,需要构建一个超市信息管理系统。
    根据需求分析阶段收集的信息,设计的实体联系图和关系模式(不完整)如下:【需求分析结果】
    1)超市信息包括:超市名称、地址、经理和电话,其中超市名称唯一确定超市关系的每一个元组。每个超市只有一名经理。
    2)超市设有计划部、财务部、销售部等多个部门,每个部门只有一名部门经理,有多名员工,每个员工只属于一个部门。部门信息包括:超市名称、部门名称、部门经理和。超市名称、部门名称唯一确定部门关系的每一个元组。
    3)员工信息包括:员工号、姓名、超市名称、部门名称、职位、和工资。其中,职位信息包括:经理、部门经理、业务员等。员工号唯一确定员工关系的每一个元组。
    4)商品信息包括:商品号、商品名称、型号、单价和数量。商品号唯一确定商品关系的每一个元组。一名业务员可以负责超市内多种商品的配给,一种商品可以由多名业务员配给。
【概念模型设计】
1-1  实体联系图
【关系模式设计】
      超市(超市名称,经理,地址,电话)
      部门(  a ,部门经理,)
      员工(  b ,姓名,,职位,工资)
      商品(商品号,商品名称,型号,单价,数量)
      配给(  c  ,配给时间,配给数量,业务员)
【问题1】(4分)
根据问题描述,补充四个联系,完善图1-1的实体联系图。联系名可用联系1、联系2、联系3和联系4代替,联系的类型分为1:11:nm:n(或1:11:**:*)。
图略
【问题2】(7分)
1)根据实体联系图,将关系模式中的空(a)~(c)补充完整;
(a) 超市名称、部门名称
(b) 员工号、超市名称、部门名称
(c) 商品号
2)给出部门和配给关系模式的主键和外键。
部门:  主键:超市名称、部门名称            外键:超市名称、部门经理
配给:  主键:业务员、商品号、配给时间      外键:业务员、商品号
【问题3】(4分)
1)超市关系的地址可以进一步分为邮编、省、市、街道,那么该属性是属于简单属性还是复合属性?请用100字以内文字说明。
复合属性;因为简单属性是原子的、不可再分的,而复合属性可以进一步细分,例如:超市关系的地址可以进一步分为邮编、省、市、街道。
    2)假设超市需要增设一个经理的职位,那么超市与经理之间的联系类型应修改为  d1:* ,超市关系应修改为e超市(超市名称,地址,电话) 
试题:3
阅读下列说明和图,回答问题1至问题3,将解答填入答题纸的对应栏内。
【说明】
    某公司欲开发一个管理选民信息的软件系统。系统的基本需求描述如下:
    1)每个人(Person)可以是一个合法选民(Eligible)或者无效的选民(Ineligible)
    2)每个合法选民必须通过该系统对其投票所在区域(即选区,Riding)进行注册( Registration)每个合法选民仅能注册一个选区
    3)选民所属选区由其居住地址(Address)决定。假设每个人只有一个地址,地址可以是(Town)或者城市(City)
    4)某些选区可能包含多个镇;而某些较大的城市也可能包含多个选区
    现采用面向对象方法对该系统进行分析与设计,得到如图1-1所示的初始类图。
1-1类图
【问题1 8分)
根据说明中的描述,给出图1-1C1C4所对应的类名(类名使用说明中给出的英文词汇)。
C1Address                    C2Riding                       
C3Ineligible                  C4Eligible
【问题2】(3分)
根据说明中的描述,给出图1-1M1M6处的多重度。
M11          M20...*          M30...*        M41      M5 : 1...*      M61...*
【问题3】(4分)
    现对该系统提出了以下新需求:
    1)某些人拥有在多个选区投票的权利,因此需要注册多个选区;
    2)对于满足(1)的选民,需要划定其“主要居住地”,以确定他们应该在哪个选区进行投票。
为了满足上述需求,需要对图1-1所示的类图进行哪些修改?请用100字以内文字说明。
M4的多重度改为1...*;增加一个类主要居住地,每个主要居住地包括选区Riding ,每个选区只有一个主要居住地。
试题:4
阅读下列说明和C代码,回答问题1至问题3,将解答写在答题纸的对应栏内。
【说明】
    计算一个整数数组a的最长递增子序列长度的方法描述如下:
    假设数组a的长度为n,用数组b的元素b[i]记录以a[i](0i<n)为结尾元素的最长递增予序列的长度,则数组a的最长递增子序列的长度为;其中b[i]满足最优子结构,可递归定义为:
C代码】
    下面是算法的C语言实现。
    1)常量和变量说明
        a:长度为n的整数数组,待求其最长递增子序列
        b:长度为n的数组,b[i]记录以a[i](0i<n)为结尾元素的最长递增子序列的长
度,其中0i<n
        len:最长递增子序列的长度
        i,j:循环变量
        temp:临时变量
    2C程序
#include <stdio.h>
int maxL(int*b, int n) {
  int i, temp=0;
  for(i=0; i<n; i++) {
    if(b[i]>temp)
      temp=b[i];
  }
  return temp;
}
int main() {
  int n, a[100], b[100], i, j, len;
  scanf("%d", &n);
  for(i=0; i<n; i++) {     
    scanf("%d", &a[i]);
  }
      (1)     ;
  for(i=1; i<n; i++) {
    for(j=0, len=0;   (2)    ; j++) {
      if(    (3)   && len<b[j]) 
        len=b[j];
    }
        (4)   ;
  }
  Printf("len:%d\n", maxL(b,n));
  printf("\n");
}
【问题1】(8分)
根据说明和C代码,填充C代码中的空(1)~(4)。
(1) b[0]=1    (2) j<=i    (3) a[j] <=a[i]    (4) b[j]=b[j]+a[i]
【问题2】(4分) 
    根据说明和C代码,算法采用了 5 贪心设计策略,时间复杂度为 6O(n*n) (用O符号表示)。   
【问题3】(3分)
已知数组a={3,10,5,15,6,8},根据说明和C代码,给出数组b的元素值。
b=66;
试题:5 
阅读下列说明和C++代码,将应填入 n 处的字句写在答题纸的对应栏内。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。