1、二级公共基础知识总结第一章 数据结构与算法1.1 算法算法:是指解题方案的准确而完整的描述。算法不等于程序,也不等计算机方法,程序的编制不也许优于算法的设计。算法的基本特性:是一组严谨地定义运算顺序的规则,每一个规则都是有效的,是明确的,此顺序将在有限的次数下终止。特性涉及:(1)可行性;(2)拟定性,算法中每一环节都必须有明拟定义,不充许有模棱两可的解释,不允许有多义性;(3)有穷性,算法必须能在有限的时间内做完,即能在执行有限个环节后终止,涉及合理的执行时间的含义;(4)拥有足够的情报。算法的基本要素:一是对数据对象的运算和操作;二是算法的控制结构。指令系统:一个计算机系统能执行的所有指令
2、的集合。基本运算涉及:算术运算、逻辑运算、关系运算、数据传输。算法的控制结构:顺序结构、选择结构、循环结构。算法基本设计方法:列举法、归纳法、递推、递归、减斗递推技术、回溯法。算法复杂度:算法时间复杂度和算法空间复杂度。算法时间复杂度是指执行算法所需要的计算工作量。算法空间复杂度是指执行这个算法所需要的内存空间。1.2 数据结构的基本基本概念数据结构研究的三个方面:(1)数据集合中各数据元素之间所固有的逻辑关系,即数据的逻辑结构;(2)在对数据进行解决时,各数据元素在计算机中的存储关系,即数据的存储结构;(3)对各种数据结构进行的运算。数据结构是指互相有关联的数据元素的集合。数据的逻辑结构包含
3、:(1)表达数据元素的信息;(2)表达各数据元素之间的前后件关系。数据的存储结构有顺序、链接、索引等。线性结构条件:(1)有且只有一个根结点;(2)每一个结点最多有一个前件,也最多有一个后件。非线性结构:不满足线性结构条件的数据结构。13 线性表及其顺序存储结构线性表是由一组数据元素构成,数据元素的位置只取决于自己的序号,元素之间的相对位置是线性的。在复杂线性表中,由若干项数据元素组成的数据元素称为记录,而由多个记录构成的线性表又称为文献。非空线性表的结构特性:(1)且只有一个根结点a1,它无前件;(2)有且只有一个终端结点an,它无后件;(3)除根结点与终端结点外,其他所有结点有且只有一个前
4、件,也有且只有一个后件。结点个数n称为线性表的长度,当n=0时,称为空表。线性表的顺序存储结构具有以下两个基本特点:(1)线性表中所有元素的所占的存储空间是连续的;(2)线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。ai的存储地址为:ADR(ai)=ADR(a1)+(i-1)k,,ADR(a1)为第一个元素的地址,k代表每个元素占的字节数。顺序表的运算:插入、删除。 (详见14-16页)14 栈和队列栈是限定在一端进行插入与删除的线性表,允许插入与删除的一端称为栈顶,不允许插入与删除的另一端称为栈底。栈按照“先进后出”(FILO)或“后进先出”(LIFO)组织数据,栈具有记忆作用。用t
5、op表达栈顶位置,用bottom表达栈底。栈的基本运算:(1)插入元素称为入栈运算;(2)删除元素称为退栈运算;(3)读栈顶元素是将栈顶元素赋给一个指定的变量,此时指针无变化。队列是指允许在一端(队尾)进入插入,而在另一端(队头)进行删除的线性表。Rear指针指向队尾,front指针指向队头。队列是“先进行出”(FIFO)或“后进后出”(LILO)的线性表。队列运算涉及(1)入队运算:从队尾插入一个元素;(2)退队运算:从队头删除一个元素。循环队列:s=0表达队列空,s=1且front=rear表达队列满15 线性链表数据结构中的每一个结点相应于一个存储单元,这种存储单元称为存储结点,简称结点
6、。结点由两部分组成:(1)用于存储数据元素值,称为数据域;(2)用于存放指针,称为指针域,用于指向前一个或后一个结点。在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的存储顺序与数据元素之间的逻辑关系可以不一致,而数据元素之间的逻辑关系是由指针域来拟定的。链式存储方式即可用于表达线性结构,也可用于表达非线性结构。线性链表,HEAD称为头指针,HEAD=NULL(或0)称为空表,假如是两指针:左指针(Llink)指向前件结点,右指针(Rlink)指向后件结点。线性链表的基本运算:查找、插入、删除。16 树与二叉树树是一种简朴的非线性结构,所有元素之间具有明显的层次特性。在树结构中,
7、每一个结点只有一个前件,称为父结点,没有前件的结点只有一个,称为树的根结点,简称树的根。每一个结点可以有多个后件,称为该结点的子结点。没有后件的结点称为叶子结点。在树结构中,一个结点所拥有的后件的个数称为该结点的度,所有结点中最大的度称为树的度。树的最大层次称为树的深度。二叉树的特点:(1)非空二叉树只有一个根结点;(2)每一个结点最多有两棵子树,且分别称为该结点的左子树与右子树。二叉树的基本性质:(1)在二叉树的第k层上,最多有2(k-1) (k1)个结点;(2)深度为m的二叉树最多有(2m)-1个结点;(3)度为0的结点(即叶子结点)总是比度为2的结点多一个;(4)具有n个结点的二叉树,其
8、深度至少为log2n+1,其中log2n表达取log2n的整数部分;(5)具有n个结点的完全二叉树的深度为log2n+1;(6)设完全二叉树共有n个结点。假如从根结点开始,按层序(每一层从左到右)用自然数1,2,.n给结点进行编号(k=1,2.n),有以下结论:若k=1,则该结点为根结点,它没有父结点;若k1,则该结点的父结点编号为INT(k/2);若2kn,则编号为k的结点的左子结点编号为2k;否则该结点无左子结点(也无右子结点);若2k+1n,则编号为k的结点的右子结点编号为2k+1;否则该结点无右子结点。满二叉树是指除最后一层外,每一层上的所有结点有两个子结点,则k层上有2k-1个结点深
9、度为m的满二叉树有2m-1个结点。完全二叉树是指除最后一层外,每一层上的结点数均达成最大值,在最后一层上只缺少右边的若干结点。二叉树存储结构采用链式存储结构,对于满二叉树与完全二叉树可以按层序进行顺序存储。二叉树的遍历:(1)前序遍历(DLR),一方面访问根结点,然后遍历左子树,最后遍历右子树;(2)中序遍历(LDR),一方面遍历左子树,然后访问根结点,最后遍历右子树;(3)后序遍历(LRD)一方面遍历左子树,然后访问遍历右子树,最后访问根结点。17 查找技术顺序查找的使用情况:(1)线性表为无序表;(2)表采用链式存储结构。二分法查找只合用于顺序存储的有序表,对于长度为n的有序线性表,最坏情
10、况只需比较log2n次。18 排序技术排序是指将一个无序序列整理成按值非递减顺序排列的有序序列。互换类排序法:(1)冒泡排序法,需要比较的次数为n(n-1)/2; (2)快速排序法。插入类排序法:(1)简朴插入排序法,最坏情况需要n(n-1)/2次比较;(2)希尔排序法,最坏情况需要O(n1.5)次比较。选择类排序法:(1)简朴选择排序法, 最坏情况需要n(n-1)/2次比较;(2)堆排序法,最坏情况需要O(nlog2n)次比较。第二章程序设计基础21 程序设计设计方法和风格如何形成良好的程序设计风格1、源程序文档化; 2、数据说明的方法;3、语句的结构; 4、输入和输出。注释分序言性注释和功
11、能性注释,语句结构清楚第一、效率第二。22 结构化程序设计结构化程序设计方法的四条原则是:1. 自顶向下;2. 逐步求精;3.模块化;4.限制使用goto语句。结构化程序的基本结构和特点:(1)顺序结构:一种简朴的程序设计,最基本、最常用的结构;(2)选择结构:又称分支结构,涉及简朴选择和多分支选择结构,可根据条件,判断应当选择哪一条分支来执行相应的语句序列;(3)循环结构:可根据给定条件,判断是否需要反复执行某一相同程序段。23 面向对象的程序设计面向对象的程序设计:以60年代末挪威奥斯陆大学和挪威计算机中心研制的SIMULA语言为标志。面向对象方法的优点:(1)与人类习惯的思维方法一致;(
12、2)稳定性好;(3)可重用性好;(4)易于开发大型软件产品;(5)可维护性好。对象是面向对象方法中最基本的概念,可以用来表达客观世界中的任何实体,对象是实体的抽象。面向对象的程序设计方法中的对象是系统中用来描述客观事物的一个实体,是构成系统的一个基本单位,由一组表达其静态特性的属性和它可执行的一组操作组成。属性即对象所包含的信息,操作描述了对象执行的功能,操作也称为方法或服务。对象的基本特点:(1)标记惟一性;(2)分类性;(3)多态性;(4)封装性;(5)模块独立性好。类是指具有共同属性、共同方法的对象的集合。所以类是对象的抽象,对象是相应类的一个实例。消息是一个实例与另一个实例之间传递的信
13、息。消息的组成涉及(1)接受消息的对象的名称;(2)消息标记符,也称消息名;(3)零个或多个参数。继承是指可以直接获得已有的性质和特性,而不必反复定义他们。继承分单继承和多重继承。单继承指一个类只允许有一个父类,多重继承指一个类允许有多个父类。多态性是指同样的消息被不同的对象接受时可导致完全不同的行动的现象第三章软件工程基础31 软件工程基本概念计算机软件是涉及程序、数据及相关文档的完整集合。软件的特点涉及:(1)软件是一种逻辑实体;(2)软件的生产与硬件不同,它没有明显的制作过程;(3)软件在运营、使用期间不存在磨损、老化问题;(4)软件的开发、运营对计算机系统具有依赖性,受计算机系统的限制
14、,这导致了软件移植的问题;(5)软件复杂性高,成本昂贵;(6)软件开发涉及诸多的社会因素。软件按功能分为应用软件、系统软件、支撑软件(或工具软件)。软件危机重要表现在成本、质量、生产率等问题。软件工程是应用于计算机软件的定义、开发和维护的一整套方法、工具、文档、实践标准和工序。软件工程涉及3个要素:方法、工具和过程。软件工程过程是把软件转化为输出的一组彼此相关的资源和活动,包含4种基本活动:(1)P软件规格说明;(2)D软件开发;(3)C软件确认;(4)A软件演进。软件周期:软件产品从提出、实现、使用维护到停止使用退役的过程。软件生命周期三个阶段:软件定义、软件开发、运营维护,重要活动阶段是:
15、(1)可行性研究与计划制定;(2)需求分析;(3)软件设计;(4)软件实现;(5)软件测试;(6)运营和维护。软件工程的目的和与原则:目的:在给定成本、进度的前提下,开发出具有有效性、可靠性、可理解性、可维护性、可重用性、可适应性、可移植性、可追踪性和可互操作性且满足用户需求的产品。基本目的:付出较低的开发成本;达成规定的软件功能;取得较好的软件性能;开发软件易于移植;需要较低的费用;能准时完毕开发,及时交付使用。基本原则:抽象、信息隐蔽、模块化、局部化、拟定性、一致性、完备性和可验证性。软件工程的理论和技术性研究的内容重要涉及:软件开发技术和软件工程管理。软件开发技术涉及:软件开发方法学、开
16、发过程、开发工具和软件工程环境。软件工程管理涉及:软件管理学、软件工程经济学、软件心理学等内容。软件管理学涉及人员组织、进度安排、质量保证、配置管理、项目计划等。软件工程原则涉及抽象、信息隐蔽、模块化、局部化、拟定性、一致性、完备性和可验证性。32 结构化分析方法结构化方法的核心和基础是结构化程序设计理论。需求分析方法有(1)结构化需求分析方法; (2)面向对象的分析的方法。从需求分析建立的模型的特性来分:静态分析和动态分析。结构化分析方法的实质:着眼于数据流,自顶向下,逐层分解,建立系统的解决流程,以数据流图和数据字典为重要工具,建立系统的逻辑模型。结构化分析的常用工具(1)数据流图; (2
17、)数据字典; (3)鉴定树; (4)鉴定表。数据流图:描述数据解决过程的工具,是需求理解的逻辑模型的图形表达,它直接支持系统功能建模。数据字典:对所有与系统相关的数据元素的一个有组织的列表,以及精确的、严格的定义,使得用户和系统分析员对于输入、输出、存储成分和中间计算结果有共同的理解。鉴定树:从问题定义的文字描述中分清哪些是鉴定的条件,哪些是鉴定的结论,根据描述材料中的连接词找出鉴定条件之间的从属关系、并列关系、选择关系,根据它们构造鉴定树。鉴定表:与鉴定树相似,当数据流图中的加工要依赖于多个逻辑条件的取值,即完毕该加工的一组动作是由于某一组条件取值的组合而引发的,使用鉴定表描述比较适宜。数据
18、字典是结构化分析的核心。软件需求规格说明书的特点:(1)对的性;(2)无岐义性;(3)完整性;(4)可验证性;(5)一致性;(6)可理解性;(7)可追踪性。33 结构化设计方法软件设计的基本目的是用比较抽象概括的方式拟定目的系统如何完毕预定的任务,软件设计是拟定系统的物理模型。软件设计是开发阶段最重要的环节,是将需求准确地转化为完整的软件产品或系统的唯一途径。从技术观点来看,软件设计涉及软件结构设计、数据设计、接口设计、过程设计。结构设计:定义软件系统各重要部件之间的关系。数据设计:将分析时创建的模型转化为数据结构的定义。接口设计:描述软件内部、软件和协作系统之间以及软件与人之间如何通信。过程
19、设计:把系统结构部件转换成软件的过程描述。从工程管理角度来看:概要设计和具体设计。软件设计的一般过程:软件设计是一个迭代的过程;先进行高层次的结构设计;后进行低层次的过程设计;穿插进行数据设计和接口设计。衡量软件模块独立性使用耦合性和内聚性两个定性的度量标准。在程序结构中各模块的内聚性越强,则耦合性越弱。优秀软件应高内聚,低耦合。软件概要设计的基本任务是:(1)设计软件系统结构; (2)数据结构及数据库设计;(3)编写概要设计文档; (4)概要设计文档评审。模块用一个矩形表达,箭头表达模块间的调用关系。 在结构图中还可以用带注释的箭头表达模块调用过程中来回传递的信息。还可用带实心圆的箭头表达传
20、递的是控制信息,空心圆箭心表达传递的是数据。结构图的基本形式:基本形式、顺序形式、反复形式、选择形式。结构图有四种模块类型:传入模块、传出模块、变换模块和协调模块。典型的数据流类型有两种:变换型和事务型。变换型系统结构图由输入、中心变换、输出三部分组成。事务型数据流的特点是:接受一项事务,根据事务解决的特点和性质,选择分派一个适当的解决单元,然后给出结果。具体设计:是为软件结构图中的每一个模块拟定实现算法和局部数据结构,用某种选定的表达工具表达算法和数据结构的细节。常见的过程设计工具有:图形工具(程序流程图)、表格工具(鉴定表)、语言工具(PDL)。34 软件测试软件测试定义:使用人工或自动手
21、段来运营或测定某个系统的过程,其目的在于检查它是否满足规定的需求或是弄清预期结果与实际结果之间的差别。软件测试的目的:发现错误而执行程序的过程。软件测试方法:静态测试和动态测试。静态测试涉及代码检查、静态结构分析、代码质量度量。不实际运营软件,重要通过人工进行。动态测试:是基本计算机的测试,重要涉及白盒测试方法和黑盒测试方法。白盒测试:在程序内部进行,重要用于完毕软件内部CAO作的验证。重要方法有逻辑覆盖、基本基途径测试。黑盒测试:重要诊断功能不对或漏掉、界面错误、数据结构或外部数据库访问错误、性能错误、初始化和终止条件错,用于软件确认。重要方法有等价类划分法、边界值分析法、错误推测法、因果图
22、等。软件测试过程一般按4个环节进行:单元测试、集成测试、验收测试(确认测试)和系统测试。35 程序的调试程序调试的任务是诊断和改正程序中的错误,重要在开发阶段进行。程序调试的基本环节:(1)错误定位;(2)修改设计和代码,以排除错误;(3)进行回归测试,防止引进新的错误。软件调试可分表静态调试和动态调试。静态调试重要是指通过人的思维来分析源程序代码和排错,是重要的设计手段,而动态调试是辅助静态调试。重要调试方法有:(1)强行排错法;(2)回溯法;(3)因素排除法。第四章 数据库设计基础41 数据库系统的基本概念数据:事实上就是描述事物的符号记录。数据的特点:有一定的结构,有型与值之分,如整型、
23、实型、字符型等。而数据的值给出了符合定型的值,如整型值15。数据库:是数据的集合,具有统一的结构形式并存放于统一的存储介质内,是多种应用数据的集成,并可被各个应用程序共享。数据库存放数据是按数据所提供的数据模式存放的,具有集成与共享的特点。数据库管理系统:一种系统软件,负责数据库中的数据组织、数据操纵、数据维护、控制及保护和数据服务等,是数据库的核心。数据库管理系统功能:(1)数据模式定义:即为数据库构建其数据框架;(2)数据存取的物理构建:为数据模式的物理存取与构建提供有效的存取方法与手段;(3)数据操纵:为用户使用数据库的数据提供方便,如查询、插入、修改、删除等以及简朴的算术运算及记录;(
24、4)数据的完整性、安生性定义与检查;(5)数据库的并发控制与故障恢复;(6)数据的服务:如拷贝、转存、重组、性能监测、分析等。为完毕以上六个功能,数据库管理系统提供以下的数据语言:(1)数据定义语言:负责数据的模式定义与数据的物理存取构建;(2)数据操纵语言:负责数据的操纵,如查询与增、删、改等;(3)数据控制语言:负责数据完整性、安全性的定义与检查以及并发控制、故障恢复等。数据语言按其使用方式具有两种结构形式:交互式命令(又称自含型或自主型语言)宿主型语言(一般可嵌入某些宿主语言中)。数据库管理员:对数据库进行规划、设计、维护、监视等的专业管理人员。数据库系统:由数据库(数据)、数据库管理系
25、统(软件)、数据库管理员(人员)、硬件平台(硬件)、软件平台(软件)五个部分构成的运营实体。数据库应用系统:由数据库系统、应用软件及应用界面三者组成。文献系统阶段:提供了简朴的数据共享与数据管理能力,但是它无法提供完整的、统一的、管理和数据共享的能力。层次数据库与网状数据库系统阶段 :为统一与共享数据提供了有力支撑。关系数据库系统阶段数据库系统的基本特点:数据的集成性 、数据的高共享性与低冗余性 、数据独立性(物理独立性与逻辑独立性)、数据统一管理与控制。数据库系统的三级模式:(1)概念模式:数据库系统中全局数据逻辑结构的描述,全体用户公共数据视图;(2)外模式:也称子模式与用户模式。是用户的
26、数据视图,也就是用户所见到的数据模式;(3)内模式:又称物理模式,它给出了数据库物理存储结构与物理存取方法。数据库系统的两级映射:(1)概念模式到内模式的映射;(2)外模式到概念模式的映射。4.2 数据模型数据模型的概念:是数据特性的抽象,从抽象层次上描述了系统的静态特性、动态行为和约束条件,为数据库系统的信息表与操作提供一个抽象的框架。描述了数据结构、数据操作及数据约束。E-R模型的基本概念(1)实体:现实世界中的事物;(2)属性:事物的特性;(3)联系:现实世界中事物间的关系。实体集的关系有一对一、一对多、多对多的联系。E-R模型三个基本概念之间的联接关系:实体是概念世界中的基本单位,属性
27、有属性域,每个实体可取属性域内的值。一个实体的所有属性值叫元组。E-R模型的图示法:(1)实体集表达法; (2)属性表法; (3)联系表达法。层次模型的基本结构是树形结构,具有以下特点:(1)每棵树有且仅有一个无双亲结点,称为根;(2)树中除根外所有结点有且仅有一个双亲。从图论上看,网状模型是一个不加任何条件限制的无向图。关系模型采用二维表来表达,简称表,由表框架及表的元组组成。一个二维表就是一个关系。在二维表中凡能唯一标记元组的最小属性称为键或码。从所有侯选健中选取一个作为用户使用的键称主键。表A中的某属性是某表B的键,则称该属性集为A的外键或外码。关系中的数据约束:(1)实体完整性约束:约
28、束关系的主键中属性值不能为空值;(2)参照完全性约束:是关系之间的基本约束;(3)用户定义的完整性约束:它反映了具体应用中数据的语义规定。4.3关系代数关系数据库系统的特点之一是它建立在数据理论的基础之上,有很多数据理论可以表达关系模型的数据操作,其中最为著名的是关系代数与关系演算。关系模型的基本运算:(1)插入 (2)删除 (3)修改 (4)查询(涉及投影、选择、笛卡尔积运算)4.4 数据库设计与管理数据库设计是数据应用的核心。数据库设计的两种方法:(1)面向数据:以信息需求为主,兼顾解决需求;(2)面向过程:以解决需求为主,兼顾信息需求。数据库的生命周期:需求分析阶段、概念设计阶段、逻辑设
29、计阶段、物理设计阶段、编码阶段、测试阶段、运营阶段、进一步修改阶段。需求分析常用结构析方法和面向对象的方法。结构化分析(简称SA)方法用自顶向下、逐层分解的方式分析系统。用数据流图表达数据和解决过程的关系。对数据库设计来讲,数据字典是进行具体的数据收集和数据分析所获得的重要结果。数据字典是各类数据描述的集合,涉及5个部分:数据项、数据结构、数据流(可以是数据项,也可以是数据结构)、数据存储、解决过程。数据库概念设计的目的是分析数据内在语义关系。设计的方法有两种(1)集中式模式设计法(合用于小型或并不复杂的单位或部门);(2)视图集成设计法。设计方法:E-R模型与视图集成。视图设计一般有三种设计
30、顺序:自顶向下、由底向上、由内向外。视图集成的几种冲突:命名冲突、概念冲突、域冲突、约束冲突。关系视图设计:关系视图的设计又称外模式设计。关系视图的重要作用:(1)提供数据逻辑独立性;(2)能适应用户对数据的不同需求;(3)有一定数据保密功能。数据库的物理设计重要目的是对数据内部物理结构作调整并选择合理的存取途径,以提高数据库访问速度有效运用存储空间。一般RDBMS中留给用户参与物理设计的内容大体有索引设计、集成簇设计和分区设计。数据库管理的内容:(1)数据库的建立;(2)数据库的调整;(3)数据库的重组;(4)数据库安全性与完整性控制;(5)数据库的故障恢复;(6)数据库监控。一、选择题(1
31、) 下面叙述对的的是(C) A. 算法的执行效率与数据的存储结构无关 B. 算法的空间复杂度是指算法程序中指令(或语句)的条数 C. 算法的有穷性是指算法必须能在执行有限个环节之后终止 D. 以上三种描述都不对(2) 以下数据结构中不属于线性数据结构的是(C) A. 队列 B. 线性表 C. 二叉树 D. 栈(3) 在一棵二叉树上第5层的结点数最多是(B) 注:由公式2k-1得 A. 8 B. 16 C. 32 D. 15(4) 下面描述中,符合结构化程序设计风格的是(A) A. 使用顺序、选择和反复(循环)三种基本控制结构表达程序的控制逻辑 B. 模块只有一个入口,可以有多个出口 C. 注重
32、提高程序的执行效率 D. 不使用goto语句(5) 下面概念中,不属于面向对象方法的是 (D) 注:P55-58 A. 对象 B. 继承 C. 类 D. 过程调用(6) 在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是(B) A. 可行性分析 B. 需求分析 C. 具体设计 D. 程序编码 (7) 在软件开发中,下面任务不属于设计阶段的是(D) A. 数据结构设计 B. 给出系统模块结构 C. 定义模块算法 D. 定义需求并建立系统模型(8) 数据库系统的核心是(B) A. 数据模型 B. 数据库管理系统 C. 软件工具 D. 数据库(9) 下列叙述中对的的是(C) A.数据
33、库是一个独立的系统,不需要操作系统的支持 B.数据库设计是指设计数据库管理系统 C.数据库技术的主线目的是要解决数据共享的问题 D.数据库系统中,数据的物理结构必须与逻辑结构一致(10) 下列模式中,可以给出数据库物理存储结构与物理存取方法的是(A) 注:P108 A. 内模式 B. 外模式 C. 概念模式 D. 逻辑模式(11) 算法的时间复杂度是指(C) A. 执行算法程序所需要的时间 B. 算法程序的长度 C. 算法执行过程中所需要的基本运算次数 D. 算法程序中的指令条数(12) 算法的空间复杂度是指(D) A. 算法程序的长度 B. 算法程序中的指令条数 C. 算法程序所占的存储空间
34、 D. 算法执行过程中所需要的存储空间(13) 设一棵完全二叉树共有699个结点,则在该二叉树中的叶子结点数为(B) 注:运用公式n=n0+n1+n2、n0=n2+1和完全二叉数的特点可求出 A. 349 B. 350 C. 255 D. 351(14) 结构化程序设计重要强调的是(B) A.程序的规模 B.程序的易读性 C.程序的执行效率 D.程序的可移植性(15) 在软件生命周期中,能准确地拟定软件系统必须做什么和必须具有哪些功能的阶段是(D) 注:即第一个阶段 A. 概要设计 B. 具体设计 C. 可行性分析 D. 需求分析(16) 数据流图用于抽象描述一个软件的逻辑模型,数据流图由一些
35、特定的图符构成。下列图符名标记的图符不属于数据流图合法图符的是(A) 注:P67 A. 控制流 B. 加工 C. 数据存储 D. 源和潭(17) 软件需求分析阶段的工作,可以分为四个方面:需求获取、需求分析、编写需求规格说明书以及(B) 注:P66 A. 阶段性报告 B. 需求评审 C. 总结 D. 都不对的(18) 下述关于数据库系统的叙述中对的的是(A) A. 数据库系统减少了数据冗余 B. 数据库系统避免了一切冗余 C. 数据库系统中数据的一致性是指数据类型的一致 D. 数据库系统比文献系统能管理更多的数据(19) 关系表中的每一横行称为一个(A) A. 元组 B. 字段 C. 属性 D
36、. 码(20) 数据库设计涉及两个方面的设计内容,它们是(A) A. 概念设计和逻辑设计 B. 模式设计和内模式设计 C. 内模式设计和物理设计 D. 结构特性设计和行为特性设计(21) 下列叙述中对的的是(A) A. 线性表是线性结构 B. 栈与队列是非线性结构 C. 线性链表是非线性结构 D. 二叉树是线性结构(22) 下列关于栈的叙述中对的的是(D) A. 在栈中只能插入数据 B. 在栈中只能删除数据 C. 栈是先进先出的线性表 D. 栈是先进后出的线性表(23) 下列关于队列的叙述中对的的是(C) A. 在队列中只能插入数据 B. 在队列中只能删除数据 C. 队列是先进先出的线性表 D
37、. 队列是先进后出的线性表(24) 对建立良好的程序设计风格,下面描述对的的是(A) 注:P48 A. 程序应简朴、清楚、可读性好 B. 符号名的命名要符合语法 C. 充足考虑程序的执行效率 D. 程序的注释可有可无(25) 下面对对象概念描述错误的是(A) 注:P55 A. 任何对象都必须有继承性 B. 对象是属性和方法的封装体 C. 对象间的通讯靠消息传递 D. 操作是对象的动态性属性(26) 下面不属于软件工程的3个要素的是(D) 注:P62 A. 工具 B. 过程 C. 方法 D. 环境(27) 程序流程图(PFD)中的箭头代表的是(B) 注:P81 A. 数据流 B. 控制流 C.
38、调用关系 D. 组成关系(28) 在数据管理技术的发展过程中,经历了人工管理阶段、文献系统阶段和数据库系统阶段。其中数据独立性最高的阶段是(A) A. 数据库系统 B. 文献系统 C. 人工管理 D. 数据项管理(29) 用树形结构来表达实体之间联系的模型称为(B) A. 关系模型 B. 层次模型 C. 网状模型 D. 数据模型(30) 关系数据库管理系统能实现的专门关系运算涉及(B) A. 排序、索引、记录 B. 选择、投影、连接 C. 关联、更新、排序 D. 显示、打印、制表(31) 算法一般都可以用哪几种控制结构组合而成(D) 注:P3 A. 循环、分支、递归 B. 顺序、循环、嵌套 C
39、. 循环、递归、选择 D. 顺序、选择、循环(32) 数据的存储结构是指(B) 注:P13,要牢记 A. 数据所占的存储空间量 B. 数据的逻辑结构在计算机中的表达 C. 数据在计算机中的顺序存储方式 D. 存储在外存中的数据(33) 设有下列二叉树: 对此二叉树中序遍历的结果为(B) A. ABCDEF B. DBEAFC C. ABDECF D. DEBFCA(34) 在面向对象方法中,一个对象请求另一对象为其服务的方式是通过发送(D) 注:P56 A. 调用语句 B. 命令 C. 口令 D. 消息(35) 检查软件产品是否符合需求定义的过程称为(A) 注:P95 A. 确认测试 B. 集
40、成测试 C. 验证测试 D. 验收测试(36) 下列工具中属于需求分析常用工具的是(D) 注:P67 A. PAD B. PFD C. N-S D. DFD(37) 下面不属于软件设计原则的是(C) 注:P73 A. 抽象 B. 模块化 C. 自底向上 D. 信息隐蔽(38) 索引属于(B) A. 模式 B. 内模式 C. 外模式 D. 概念模式(39) 在关系数据库中,用来表达实体之间联系的是(D) A. 树结构 B. 网结构 C. 线性表 D. 二维表(40) 将E-R图转换到关系模式时,实体与联系都可以表达成(B) A. 属性 B. 关系 C. 键 D. 域(41) 在下列选项中,哪个不
41、是一个算法一般应当具有的基本特性(C) A. 拟定性 B. 可行性 C. 无穷性 D. 拥有足够的情报(42) 希尔排序法属于哪一种类型的排序法(B) A.互换类排序法 B.插入类排序法 C.选择类排序法 D.建堆排序法(43) 在深度为5的满二叉树中,叶子结点的个数为(C) A. 32 B. 31 C. 16 D. 15(44) 对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为(B) 注:要牢记 A. N+1 B. N C. (N+1)/2 D. N/2(45) 信息隐蔽的概念与下述哪一种概念直接相关(B) 注:P74 A.软件结构定义 B. 模块独立性 C. 模块类型划分 D
42、. 模拟耦合度(46) 面向对象的设计方法与传统的的面向过程的方法有本质不同,它的基本原理是(C) A. 模拟现实世界中不同事物之间的联系 B. 强调模拟现实世界中的算法而不强调概念 C. 使用现实世界的概念抽象地思考问题从而自然地解决问题 D. 鼓励开发者在软件开发的绝大部分中都用实际领域的概念去思考(47) 在结构化方法中,软件功能分解属于下列软件开发中的阶段是(C) 注:总体设计也就是概要设计 A. 具体设计 B. 需求分析 C. 总体设计 D. 编程调试(48) 软件调试的目的是(B) 注:与软件测试要对比着复习 A.发现错误 B.改正错误 C.改善软件的性能 D.挖掘软件的潜能(49
43、) 按条件f对关系R进行选择,其关系代数表达式为(C) A. R|X|R B. R|X|Rf C. f(R) D. f(R)(50) 数据库概念设计的过程中,视图设计一般有三种设计顺序,以下各项中不对的是(D) 注:P127,要牢记 A. 自顶向下 B. 由底向上 C. 由内向外 D. 由整体到局部(51) 在计算机中,算法是指(C) A. 查询方法 B. 加工方法 C. 解题方案的准确而完整的描述 D. 排序方法(52) 栈和队列的共同点是(C) 注:这一共同点和线性表不同样 A. 都是先进后出 B. 都是先进先出 C. 只允许在端点处插入和删除元素 D. 没有共同点(53) 已知二叉树后序
44、遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是(A) 注:P38,前提纲掌握三种遍历的方法 A. cedba B. acbed C. decab D. deabc(54) 在下列几种排序方法中,规定内存量最大的是(D) 注:要牢记,书中没有提到。 A. 插入排序 B. 选择排序 C. 快速排序 D. 归并排序(55) 在设计程序时,应采纳的原则之一是(A) 注:和设计风格有关 A. 程序结构应有助于读者理解 B. 不限制goto语句的使用 C. 减少或取消注解行 D. 程序越短越好(56) 下列不属于软件调试技术的是(B) 注:P98 A. 强行排错法 B. 集成测试法 C. 回溯法 D. 因素排除法(57)下列叙述中,不属于软件需求规格说明书的作用的是(D)注:P71 A. 便于用户、开发人员进行理解和交流 B. 反映出用户问题的结构,可以作为软件开发工作的基础和依据 C. 作为确认测试和验收的依据 D. 便于开发人员进行需求分析(58) 在数据流图(DFD)中,带有名字的