软件工程导论课后习题答案.docx
- 文档编号:15763732
- 上传时间:2023-07-07
- 格式:DOCX
- 页数:26
- 大小:955.87KB
软件工程导论课后习题答案.docx
《软件工程导论课后习题答案.docx》由会员分享,可在线阅读,更多相关《软件工程导论课后习题答案.docx(26页珍藏版)》请在冰点文库上搜索。
软件工程导论课后习题答案
软件工程导论(第5版)课后习题答案(总21页)
1-5根据历史数据可以做出如下的假设:
对计算机存储容量的需求大致按下面公式描述的趋势逐年增加:
M=(Y-1960)
存储器的价格按下面公式描述的趋势逐年下降:
P1=×(美分/位)
如果计算机字长为16位,则存储器价格下降的趋势为:
P2=×(美元/字)
在上列公式中Y代表年份,M是存储容量(字数),P1和P2代表价格。
基于上述假设可以比较计算机硬件和软件成本的变化趋势。
要求计算:
(1)在1985年对计算机存储容量的需求估计是多少如果字长为16位,这个存储器的价格是多少
(2)假设在1985年一名程序员每天可开发出10条指令,程序员的平均工资是每月4000美元。
如果一条指令为一个字长,计算使存储器装满程序所需用的成本。
(3)假设在1995年存储器字长为32位,一名程序员每天可开发出30条指令,程序员的月平均工资为6000美元,重复
(1)、
(2)题。
(1)在1985年对计算机存储容量的需求,估计是
M=(1985-1960)=4474263(字)
如果字长为16位,则这个存储器的价格是
P=*1985-1974*4474263=$5789
(2)如果一条指令的长度为一个字,则使存储器装满程序共需4474263条指令。
在1985年一名程序员每天可开发出10条指令,如果每月有20个工作日,则每人每月可开发出10×20条指令。
为了开发出4474263条指令以装满存储器,需要的工作量是:
4474263/200=22371(人月)
程序员的月平均工资是4000美元,开发出4474263条指令的成本是
22371*4000=¥
(3)在1995年对存储容量的需求估计为:
M=4080E0。
28(1995-1960)=(字)=
如果字长为32位,则这个存储器的价格是:
P=*32*(1995-1974)*=$7127
如果一条指令为一个字长,则为使存储器装满程序共需73,577,679条指令。
在1995年一名程序员每天可开发出30条指令,每月可开发出600条指令,为了开发出可装满整个存储器的程序,需要的工作量为
/600=122629(人月)
开发上述程序的成本为:
122629*6000=$0
1-6什么是软件过程它与软件工程方法学有何关系
软件过程是为了开发出高质量的软件产品所需完成的一系列任务的框架,它规定了完成各项任务的工作步骤。
软件过程定义了运用技术方法的顺序、应该交付的文档资料、为保证软件质量和协调软件变化必须采取的管理措施,以及标志完成了相应开发活动的里程碑。
软件过程是软件工程方法学的3个重要组成部分之一。
2-4目前住院病人主要由护士护理,这样做不仅需要大量护士,而且由于不能随时观察危重病人的病情变化,还会延误抢救时机。
某医院打算开发一个以计算机为中心的患者监护系统,请分层次地画出描述本系统功能的数据流图。
医院对患者8监护系统的基本要求是随时接收每个病人的生理信号(脉搏、体温、血压、心电图等),定时记录病人情况以形成患者日志,当某个病人的生理信号超出医生规定的安全范围时向值班护士发出警告信息,此外,护士在需要时还可以要求系统印出某个指定病人的病情报告。
从问题陈述可知,本系统数据源点是“病人”和“护士”,他们分别提供生理信号和要求病情报告的信息。
进一步分析问题陈述,从系统应该“定时记录病人情况以形成患者日志”这项要求可以想到,还应该有一个提供日期和时间信息的“时钟”作为数据源点。
从问题陈述容易看出,本系统的数据终点是接收警告信息和病情报告的护士。
系统对病人生理信号的处理功能主要是“接收信号”、“分析信号”和“产生警告信息”。
此外,系统还应该具有“定时取样生理信号”、“更新日志”和“产生病情报告”的功能。
为了分析病人生理信号是否超出了医生规定的安全范围,应该存储“患者安全范围”信息。
此外,定时记录病人生理信号所形成的“患者日志”,显然也是一个数据存储。
2-5北京某高校可用的电话号码有以下几类:
校内电话号码由4位数字组成,第1位数字不是0;校外电话又分为本市电话和外地电话两类,拨校外电话需先拨0,若是本市电话则再接着拨8位数字(第1位不是0),若是外地电话则拨3位区码再拨8位电话号码(第1位不是0)。
请用定义数据字典的方法,定义上述的电话号码。
数据结构的描述
符号含义举例
=被定义为
+与x=a+b
[...,...]或[...|...]或x=[a,b],x=[a|b]
{...}或m{...}n重复x={a},x=3{a}8
(...)可选x=(a)
“...”基本数据元素x=“a”
..连结符x=1..9
电话号码=[校内电话号码|校外电话号码]
校内电话号码=非零数字+3位数字
.]表示可选项;
符号a|b表示a或b。
假设有这样一个有穷状态机:
以一串字符为输入,判断字符串中是否含有合法的浮点二进制数。
试对这个有穷状态机进行规格说明。
该有穷状态机的初态是“等待字符串输人”。
在初态若接收到字符十、或字符一、或二进制位,则进人“输人尾数”状态;在初态若接收到其他字符,则进人终态“非浮点二进制数”。
在“输人尾数”状态若接收到二进制位,则保持该状态不变;若接收到字符E,则进人“等待输人指数”状态;若接收到其他字符,则进人终态“非浮点二进制数”。
在“等待输人指数”状态若接收到字符+、或字符一、或二进制位,则进人“输人指数”状态;若接收到其他字符,则进人终态“非浮点二进制数”。
在“输人指数”状态若接收到二进制位,则保持该状态不变;若输人其他字符,则进人终态“非浮点二进制数”;若输人结束,则进人终态“浮点二进制数”。
仔细研究图示的有穷状态机可以发现,它还有不够严格的地方。
有兴趣的同学请进一步改进它,画出更严格的、与浮点二进制数定义完全一致的有穷状态机。
补充1:
请为某仓库的管理设计一个ER模型。
该仓库主要管理零件的订购和供应等事项。
仓库向工程项目供应零件,并且根据需要向供应商订购零件。
本问题中共有三类实体,分别是“零件”、“工程项目”和“供应商”。
一种零件可供应多个工程项目,一个工程项目需要使用多种零件,因此,零件与工程项目之间的联系“供应”,是多对多(M'N)联系;类似地,零件与供应商之间的联系“订购”,也是多对多(M'N)联系。
实体类型“零件”的主要属性是:
零件编号,零件名称,颜色,重量。
实体类型“工程项目”的属性主要是:
项目编号,项目名称,开工日期。
实体类型“供应商”的属性主要有:
供应商编号,供应商名称,地址。
联系类型“供应”的属性是,向某工程项目供应的某种零件的数量。
联系类型“订购”的属性是,向某供应商订购的某种零件的数量
补充3、已知某定货系统的需求分析DFD图如下,请按SD方法的设计步骤画出结构图。
补充4、已知某系统的需求分析给出的系统数据流程图如下,画出结构图
P104:
3用面向数据流的方法设计下列系统的软件结构
(1)储蓄系统2-2
(2)机票预定系统2-3
为了方便旅客,某航空公司拟开发一个机票预定系统。
旅行社把预定机票的旅客信息(姓名、性别、工作单位、身份证号码、旅行时间、旅行目的地等)输入该系统,系统为旅客安排航班,旅客在飞机起飞前一天凭取票通知和账单交款取票,系统核对无误即印出机票给顾客
(2)患者监护系统2-4
可以是两个子系统,预定和取票是不同的处理方式(后台批量和前台单个)
P104:
4
美国某大学有200名教师,校方与教师工会刚刚签订一项协议。
按照协议,所有年工资超过$26000(含$26000)的教师工资将保持不变,年工资少于$26000的教师将增加工资,所增加工资数额按下述方法计算:
给每位教师所赡养的人(包括教师本人)每年补助$100,此外,教师有一年工龄每年再多补助¥50,但是,增加后的年工资总额不能多于$26000。
教师工资档案存储在行政办公室的磁带上,档案中有目前的年工资、赡养的人数、雇佣日期等信息。
需要写一个程序计算并印出每名教师的原工资和调整后的新工资。
要求:
(1)画出此系统的数据流图;
(2)写出需求说明;
(3)设计上述的工资调整程序(要求用HIPO图描绘设计结果),设计时分别采用两种算法,并比较两种算法的优缺点:
(a)搜索工资档案数据,找出年工资少于$26000的人,计算新工资,校核是否超过$26000,存储新工资,印出新旧工资对照表;
(b)把工资档案数据按工资从最低到最高的次序排序,当工资数额超过$26000时即停止排序,计算新工资,校核是否超过限额,存储新工资,印出结果。
(4)你所画出的数据流图适应用那种算法
补充5:
求解杨辉三角形系数
P131:
3画出下列伪码程序的程序流程图和盒图
START
IFpTHEN
WHILEqDO
f
ENDDO
ELSE
BLOCK
g
n
ENDBLOCK
ENDIF
STOP
P131:
4下图给出的程序流程图代表一个非结构化的程序,请问:
(1)为什么说它是非结构化的
(2)设计一个等价的结构化程序。
(3)在
(2)题的设计中你使用附加的标志变量flag吗若没用,请再设计一个使用flag的程序;若用了,再设计一个不用flag的程序
(1)通常所说的结构化程序,是按照狭义的结构程序的定义衡量,符合定义规定的程序。
图示的程序的循环控制结构有两个出口,显然不符合狭义的结构程序的定义,因此是非结构化的程序。
(2)使用附加的标志变量flag,至少有两种方法可以把该程序改造为等价的结构化程序,图示盒图描绘了等价的结构化程序。
(3)不使用flag把该程序改造为等价的结构化程序的方法如图所示。
P131:
8画出下列伪码程序的流图,计算它的环形复杂度。
你觉得这个程序的逻辑有什么问题吗
CEXAMPLE
LOOP:
DOWHILEX>0
A=B+1
IFA>10
THENX=A
ELSEY=Z
ENDIF
IFY<5
THENPRINTX,Y
ELSEIFY=2
THENGOTOLOOP
ELSEC=3
ENDIF
ENDIF
G=H+R
ENDDO
IFF>0
THENPRINTG
ELSEPRINTK
ENDIF
STOP
11.我们下班回家这件事,人(假如是我)就是一个对象,我们来考察一下几个状态:
1.到下班时间了,收拾东西准备回家(不考虑加班)。
2.开始等电梯。
3.到了楼下。
(发现没带家里钥匙,上楼拿)
4.上楼。
5.去公交等车。
6.乘公共汽车去菜场。
7.买菜
8.回到家
那么事件呢
1.下班时间到了(准备下班)。
2.电梯到(上电梯)
3.电梯到楼下(下电梯)
3.发现没有家里钥匙(去拿钥匙)。
4.自己要乘公共汽车到了(上车)。
5.公共汽车到站(下车)。
6.忽然想起家里没菜(去买菜)。
名称:
就是名字,状态的名字。
进入/退出动作:
对象本身的一个操作,比如在电梯里是一个状态的话,哪我们进电梯和出电梯就是状态---在电梯里---的进入/退出动作。
内部转换:
如我们在去等电梯的时候发现钥匙没带,此时我们不用在等电梯的以后状态是再有事件触发,在准备下班的状态上我们就去拿钥匙了,对于对象本身,前后两次的根本状态不一样,一个是有钥匙,一个是没有钥匙。
(子状态):
如果我们描述该对象在电梯里说话,抽烟(一般电梯不许)等状态时,该状态就是该对象状态---在电梯里---状态的子状态。
(延迟事件):
现在不立即产生的事件,该事件是在一段时间以后才产生的事件。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件工程 导论 课后 习题 答案
![提示](https://static.bingdoc.com/images/bang_tan.gif)