第一章数据结构与算法
1.1 算法
算法:是指解题方案的准确而完整的描述。
算法不等于程序,也不等于计算机方法,程序的编制不可能优于算法的设计。
ffice
ffice" />
算法的基本特征:是一组严谨地定义运算顺序的规则,每一个规则都是有效的,是明确的,此顺序将在有限的次数下终止。特征包括:
(1)可行性; (2)确定性,算法中每一步骤都必须有明确定义,不充许有模棱两可的解释,不允许有多义性; (3)有穷性,算法必须能在有限的时间内做完,即能在执行有限个步骤后终止,包括合理的执行时间的含义; (4)拥有足够的情报。
算法基本要素:一是对数据对象的运算和操作;二是算法的控制结构。
指令系统:一个计算机系统能执行的所有指令的集合。
基本运算和操作包括:算术运算、逻辑运算、关系运算、数据传输。
算法的控制结构:顺序结构、选择结构、循环结构。
算法基本设计方法:列举法、归纳法、递推、递归、减半递推技术、回溯法。
算法复杂度:算法时间复杂度和算法空间复杂度。
算法时间复杂度是指执行算法所需要的计算工作量(time)。
算法空间复杂度是指执行这个算法所需要的内存空间(room)。
1.2 数据结构的基本基本概念
数据结构研究的三个方面:
(1)数据集合中各数据元素之间所固有的逻辑关系,即数据的逻辑结构;
(2)在对数据进行处理时,各数据元素在计算机中的存储关系,即数据的存储结构;
(3)对各种数据结构进行的运算。
数据结构是指相互有关联的数据元素的集合。
数据结构的三个层次:数据逻辑结构(描述数据元素之间的逻辑关系);数据的存储结构(数据的存储方式);
数据操作集合(数据的运算)
数据的逻辑结构(线性结构和非线性结构)
包含:
(1)表示数据元素的信息:
(2)表示各数据元素之间的前后件关系。
线性结构(线性表;堆栈;队列;数组;串《字符串》)
条件:
(1)有且只有一个根结点;
(2)每一个结点最多有一个前趋,也最多有一个后继。
非线性结构(树结构;图结构)
条件:不满足线性结构条件的数据结构。
数据的存储结构有顺序、链接、索引。散列等。
1.3 线性表及其顺序存储结构
线性表由一组数据元素构成,数据元素的位置只取决于自己的序号,元素之间的相对位置是线性的。
在复杂线性表中,由若干项数据元素组成的数据元素称为记录,而由多个记录构成的线性表又称为文件。
非空线性表的结构特征:
(1)且只有一个根结点a1,它无前趋;
(2)有且只有一个终端结点an,它无后继;
(3)除根结点与终端结点外,其他所有结点有且只有一个前去,也有且只有一个后继。结点个数n称为线性表的长度,当n=0时,称为空表。
线性表的顺序存储结构具有以下两个基本特点:
(1)线性表中所有元素的所占的存储空间是连续的;
(2)线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。
ai的存储地址为:ADR(ai)=ADR(a1)+(i-1)k,,ADR(a1)为第一个元素的地址,k代表每个元素占的字节数。
顺序表的运算:插入、删除。 (详见14--16页)
1.4 栈和队列
栈是限定在一端进行插入与删除的线性表,允许插入与删除的一端称为栈顶,不允许插入与删除的另一端称为栈底。
栈按照“先进后出”(FILO)或“后进先出”(LIFO)组织数据,栈具有记忆作用。用top表示栈顶位置,用bottom表示栈底。
1.5 栈的基本运算:插入与删除的位置就是栈顶,另一端是栈尾(1)插入元素称为入栈运算;(2)删除元素称为退栈运算;(3)读栈顶元素是将栈顶元素赋给一个指定的变量,此时指针无变化。
队列是指允许在一端(队尾)进入插入,而在另一端(队头)进行删除的线性表。Rear指针指向队尾,front指针指向队头。
队列是“先进行出”(FIFO)或“后进后出”(LILO)的线性表。
队列运算包括(1)入队运算:从队尾插入一个元素;(2)退队运算:从队头删除一个元素。
循环队列:s=0表示队列空,s=1且front=rear表示队列满
1.5 线性链表
数据结构中的每一个结点对应于一个存储单元,这种存储单元称为存储结点,简称结点。
结点由两部分组成:(1)用于存储数据元素值,称为数据域;(2)用于存放指针,称为指针域,用于指向前一个或后一个结点。
在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的存储顺序与数据元素之间的逻辑关系可以不一致,而数据元素之间的逻辑关系是由指针域来确定的。
链式存储方式即可用于表示线性结构,也可用于表示非线性结构。
线性链表,HEAD称为头指针,HEAD=NULL(或0)称为空表,如果是两指针:左指针(L link)指向前件结点,右指针(R link)指向后件结点。
线性链表的基本运算:查找、插入、删除。
1.6 树与二叉树
树是一种简单的非线性结构,所有元素之间具有明显的层次特性。
在树结构中,每一个结点只有一个前件,称为父结点,没有前件的结点只有一个,称为树的根结点,简称树的根。每一个结点可以有多个后继,称为该结点的子结点。没有后件的结点称为叶子结点。
在树结构中,一个结点所拥有的后继的个数称为该结点的度,
所有结点中最大的度称为树的度。
树的最大层次称为树的深度。
二叉树的特点:(1)非空二叉树只有一个根结点;(2)每一个结点最多有两棵子树,且分别称为该结点的左子树与右子树。
二叉树的基本性质:
(1)在二叉树的第k层上,最多有2k-1(k≥1)个结点;
(2)深度为m的二叉树最多有 ffice:smarttags" />2m-1个结点;
(3)度为0的结点(即叶子结点)总是比度为2的结点多一个;
(4)具有n个结点的二叉树,其深度至少为[log2n]+1,其中[log2n]表示取log2n的整数部分; 第k层最多有2的(k-1)次方个节点。K的
(5)具有n个 结点的完全二叉树的深度为[log2n]+1;
(6)设完全二叉树共有n个结点。如果从根结点开始,按层序(每一层从左到右)用自然数1,2,….n给结点进行编号(k=1,2….n),有以下结论:
①若k=1,则该结点为根结点,它没有父结点;若k>1,则该结点的父结点编号为INT(k/2);
②若2k≤n,则编号为k的结点的左子结点编号为2k;否则该结点无左子结点(也无右子结点);
③若2k+1≤n,则编号为k的结点的右子结点编号为2k+1;否则该结点无右子结点。
满二叉树是指除最后一层外,每一层上的所有结点有两个子结点,则k层上有2k-1个结点深度为m的满二叉树有2m-1个结点。
完全二叉树是指除最后一层外,每一层上的结点数均达到最大值,在最后一层上只缺少右边的若干结点。
二叉树存储结构采用链式存储结构,对于满二叉树与完全二叉树可以按层序进行顺序存储。
二叉树的遍历:前中后指根的访问顺序,然后先左后右
(1)前序遍历(DLR),首先访问根结点,然后遍历左子树,最后遍历右子树;
(2)中序遍历(LDR),首先遍历左子树,然后访问根结点,最后遍历右子树;
(3)后序遍历(LRD)首先遍历左子树,然后访问遍历右子树,最后访问根结点。
1.7 查找技术
顺序查找的使用情况:
(1)线性表为无序表;
(2)表采用链式存储结构。
二分法查找只适用于顺序存储的有序表,对于长度为n的有序线性表,最坏情况只需比较log2n次。
1.8 排序技术
排序是指将一个无序序列整理成按值非递减顺序排列的有序序列。
交换类排序法:(1)冒泡排序法,最多需要比较的次数为n(n-1)/2; (2)快速排序法。
插入类排序法:(1)简单插入排序法,最坏情况需要n(n-1)/2次比较;(2)希尔排序法,最坏情况需要O(n1.5)次比较。
选择类排序法:(1)简单选择排序法,
最坏情况需要n(n-1)/2次比较;(2)堆排序法,最坏情况需要O(nlog2n)次比较
第二章程序设计基础
2.1 程序设计设计方法和风格
1、源程序文档化;
2、数据说明的方法;
3、语句的结构;
4、输入和输出。
注释分序言性注释和功能性注释,语句结构清晰第一、效率第二。
2.2 结构化程序设计
结构化程序设计方法的四条原则是:
1. 自顶向下;
2. 逐步求精;
3.模块化;
4.限制使用go to语句。
结构化程序的基本结构和特点:
(1)顺序结构:一种简单的程序设计,最基本、最常用的结构;
(2)选择结构:又称分支结构,包括简单选择和多分支选择结构,可根据条件,判断应该选择哪一条分支来执行相应的语句序列;
(3)循环结构:又称重复结构,可根据给定条件,判断是否需要重复执行某一相同程序段。
2.3 面向对象的程序设计
面向对象的程序设计:以60年代末挪威奥斯陆大学和挪威计算机中心研制的SIMULA语言为标志。
面向对象方法的优点:
(1)与人类习惯的思维方法一致;
(2)稳定性好;
(3)可重用性好;
(4)易于开发大型软件产品;
(5)可维护性好。
对象是面向对象方法中最基本的概念,可以用来表示客观世界中的任何实体,对象是实体的抽象。
面向对象的程序设计方法中的对象是系统中用来描述客观事物的一个实体,是构成系统的一个基本单位,由一组表示其静态特征的属性和它可执行的一组操作组成。
属性即对象所包含的信息,操作描述了对象执行的功能,操作也称为方法或服务。
对象的基本特点:
(1)标识惟一性;
(2)分类性;
(3)多态性;
(4)封装性;
(5)模块独立性好。
类是指具有共同属性、共同方法的对象的集合。所以类是对象的抽象,对象是对应类的一个实例。
消息是一个实例与另一个实例之间传递的信息。
消息的组成包括
(1)接收消息的对象的名称;
(2)消息标识符,也称消息名;
(3)零个或多个参数。
继承是指能够直接获得已有的性质和特征,而不必重复定义他们。
继承分单继承和多重继承。单继承指一个类只允许有一个父类,多重继承指一个类允许有多个父类。
多态性是指同样的消息被不同的对象接受时可导致完全不同的行动的现象。
第三章软件工程基础
3.1 软件工程基本概念
计算机软件是包括程序、数据及相关文档的完整集合。
软件的特点包括:
(1)软件是一种逻辑实体;
(2)软件的生产与硬件不同,它没有明显的制作过程;
(3)软件在运行、使用期间不存在磨损、老化问题;
(4)软件的开发、运行对计算机系统具有依赖性,受计算机系统的限制,这导致了软件移植的问题;
(5)软件复杂性高,成本昂贵;
(6)软件开发涉及诸多的社会因素。
软件按功能分为应用软件、系统软件、支撑软件(或工具软件)。
软件危机主要表现在成本、质量、生产率等问题。
软件工程是应用于计算机软件的定义、开发和维护的一整套方法、工具、文档、实践标准和工序。
软件工程包括3个要素:方法、工具和过程。
软件工程过程是把软件转化为输出的一组彼此相关的资源和活动,包含4种基本活动:
(1)P——软件规格说明;
(2)D——软件开发;
(3)C——软件确认;
(4)A——软件演进。
软件周期:软件产品从提出、实现、使用维护到停止使用退役的过程。
软件生命周期三个阶段:软件定义、软件开发、运行维护;主要活动阶段是:
(1)可行性研究与计划制定;
(2)需求分析;
(3)软件设计;
(4)软件实现;
(5)软件测试;
(6)运行和维护。
软件工程的目标和与原则:
目标:在给定成本、进度的前提下,开发出具有有效性、可靠性、可理解性、可维护性、可重用性、可适应性、可移植性、可追踪性和可互操作性且满足用户需求的产品。
基本目标:付出较低的开发成本;达到要求的软件功能;取得较好的软件性能;开发软件易于移植;需要较低的费用;能按时完成开发,及时交付使用。
基本原则:抽象、信息隐蔽、模块化、局部化、确定性、一致性、完备性和可验证性。
软件工程的理论和技术性研究的内容主要包括:软件开发技术和软件工程管理。
软件开发技术包括:软件开发方法学、开发过程、开发工具和软件工程环境。
软件工程管理包括:软件管理学、软件工程经济学、软件心理学等内容。
软件管理学包括人员组织、进度安排、质量保证、配置管理、项目计划等。
3.2 结构化分析方法
结构化方法的核心和基础是结构化程序设计理论。
需求分析方法有
(1)结构化需求分析方法;
(2)面向对象的分析的方法。
从需求分析建立的模型的特性来分:静态分析和动态分析。
结构化分析方法的实质:着眼于数据流,自顶向下,逐层分解,建立系统的处理流程,以数据流图和数据字典为主要工具,建立系统的逻辑模型。
结构化分析的常用工具
(1)数据流图; (2)数据字典; (3)判定树; (4)判定表。
数据流图:描述数据处理过程的工具,是需求理解的逻辑模型的图形表示,它直接支持系统功能建模。
数据字典:对所有与系统相关的数据元素的一个有组织的列表,以及精确的、严格的定义,使得用户和系统分析员对于输入、输出、存储成分和中间计算结果有共同的理解。
判定树:从问题定义的文字描述中分清哪些是判定的条件,哪些是判定的结论,根据描述材料中的连接词找出判定条件之间的从属关系、并列关系、选择关系,根据它们构造判定树。
判定表:与判定树相似,当数据流图中的加工要依赖于多个逻辑条件的取值,即完成该加工的一组动作是由于某一组条件取值的组合而引发的,使用判定表描述比较适宜。
数据字典是结构化分析的核心。
软件需求规格说明书的特点:
(1)正确性;
(2)无岐义性;
(3)完整性;
(4)可验证性;
(5)一致性;
(6)可理解性;
(7)可追踪性。
4.1 数据库系统的基本概念
数据:实际上就是描述事物的符号记录。
数据的特点:有一定的结构,有型与值之分,如整型、实型、字符型等。而数据的值给出了符合定型的值,如整型值15。
数据库:是数据的集合,具有统一的结构形式并存放于统一的存储介质内,是多种应用数据的集成,并可被各个应用程序共享。
数据库存放数据是按数据所提供的数据模式存放的,具有集成与共享的特点。
数据库管理系统:一种系统软件,负责数据库中的数据组织、数据操纵、数据维护、控制及保护和数据服务等,是数据库的核心。
数据库管理系统功能:
(1)数据模式定义:即为数据库构建其数据框架;
(2)数据存取的物理构建:为数据模式的物理存取与构建提供有效的存取方法与手段;
(3)数据操纵:为用户使用数据库的数据提供方便,如查询、插入、修改、删除等以及简单的算术运算及统计;
(4)数据的完整性、安生性定义与检查;
(5)数据库的并发控制与故障恢复;
(6)数据的服务:如拷贝、转存、重组、性能监测、分析等。
为完成以上六个功能,数据库管理系统提供以下的数据语言:
(1)数据定义语言:负责数据的模式定义与数据的物理存取构建;
(2)数据操纵语言:负责数据的操纵,如查询与增、删、改等;
(3)数据控制语言:负责数据完整性、安全性的定义与检查以及并发控制、故障恢复等。
数据语言按其使用方式具有两种结构形式:交互式命令(又称自含型或自主型语言)宿主型语言(一般可嵌入某些宿主语言中)。
数据库管理员:对数据库进行规划、设计、维护、监视等的专业管理人员。
数据库系统:由数据库(数据)、数据库管理系统(软件)、数据库管理员(人员)、硬件平台(硬件)、软件平台(软件)五个部分构成的运行实体。
数据库应用系统:由数据库系统、应用软件及应用界面三者组成。
文件系统阶段:提供了简单的数据共享与数据管理能力,但是它无法提供完整的、统一的、管理和数据共享的能力。
层次数据库与网状数据库系统阶段 :为统一与共享数据提供了有力支撑。
关系数据库系统阶段
数据库系统的基本特点:数据的集成性 、数据的高共享性与低冗余性 、数据独立性(物理独立性与逻辑独立性)、数据统一管理与控制。
数据库系统的三级模式:
(1)概念模式:数据库系统中全局数据逻辑结构的描述,全体用户公共数据视图;
(2)外模式:也称子模式与用户模式。是用户的数据视图,也就是用户所见到的数据模式;
(3)内模式:又称物理模式,它给出了数据库物理存储结构与物理存取方法。
数据库系统的两级映射:
(1)概念模式到内模式的映射;
(2)外模式到概念模式的映射。
4.2 数据模型
数据模型的概念:是数据特征的抽象,从抽象层次上描述了系统的静态特征、动态行为和约束条件,为数据库系统的信息表与操作提供一个抽象的框架。描述了数据结构、数据操作及数据约束。
E-R模型的基本概念
(1)实体:现实世界中的事物;
(2)属性:事物的特性;
(3)联系:现实世界中事物间的关系。实体集的关系有一对一、一对多、多对多的联系。
E-R模型三个基本概念之间的联接关系:实体是概念世界中的基本单位,属性有属性域,每个实体可取属性域内的值。一个实体的所有属性值叫元组。
E-R模型的图示法:(1)实体集表示法; (2)属性表法; (3)联系表示法。
(1) 下面叙述正确的是______。
A. 算法的执行效率与数据的存储结构无关
B. 算法的空间复杂度是指算法程序中指令(或语句)的条数(指的是算法所占用的空间)
C. 算法的有穷性是指算法必须能在执行有限个步骤之后终止
D. 以上三种描述都不对
(2) 以下数据结构中不属于线性数据结构的是______。(C)
A. 队列B. 线性表C. 二叉树D. 栈
(3) 在一棵二叉树上第5层的结点数最多是______。(B)2n-1
A. 8 B. 16 C. 32 D. 15
(4) 下面描述中,符合结构化程序设计风格的是______。(A)
A. 使用顺序、选择和重复(循环)三种基本控制结构表示程序的控制逻辑
B. 模块只有一个入口,可以有多个出口(可以有0个入口)
C. 注重提高程序的执行效率
D. 不使用goto语句(只是限制使用)
(5) 下面概念中,不属于面向对象方法的是______。(D)
A. 对象 B. 继承 C. 类 D. 过程调用
(6) 在结构化方法中,用数据流程图需求分析(DFD)作为描述工具的软件开发阶段是______。
A. 可行性分析 B. 需求分析 C. 详细设计 D. 程序编码
(7) 在软件开发中,下面任务不属于设计阶段的是______。(D)
A. 数据结构设计 B. 给出系统模块结构
C. 定义模块算法 D. 定义需求并建立系统模型
(8) 数据库系统的核心是______。(B)
A. 数据模型 B. 数据库管理系统 C. 软件工具 D. 数据库
(9) 下列叙述中正确的是______。(C)
A. 数据库是一个独立的系统,不需要操作系统的支持
B. 数据库设计是指设计数据库管理系统
C. 数据库技术的根本目标是要解决数据共享的问题
D. 数据库系统中,数据的物理结构必须与逻辑结构一致
(10) 下列模式中,能够给出数据库物理存储结构与物理存取方法的是______。(A)
A. 内模式 B. 外模式 C. 概念模式 D. 逻辑模式
(1) 算法的时间复杂度是指______。(C)
A. 执行算法程序所需要的时间 B. 算法程序的长度
C. 算法执行过程中所需要的基本运算次数 D. 算法程序中的指令条数
(2) 下列叙述中正确的是______。(A)
A. 线性表是线性结构 B. 栈与队列是非线性结构
C. 线性链表是非线性结构 D. 二叉树是线性结构
(3) 设一棵完全二叉树共有699个结点,则在该二叉树中的叶子结点数为______。(B)
A. 349 B. 350 C. 255 D. 351
(4) 结构化程序设计主要强调的是______。(B)
A. 程序的规模 B. 程序的易读性
C. 程序的执行效率 D. 程序的可移植性
(5) 在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段是______。(D)
A. 概要设计 B. 详细设计 C. 可行性分析 D. 需求分析
(6) 数据流图用于抽象描述一个软件的逻辑模型,数据流图由一些特定的图符构成。下列图符名标识的图符不属于数据流图合法图符的是______。(A)
A. 控制流 B. 加工 C. 数据存储 D. 源和潭
(7) 软件需求分析阶段的工作,可以分为四个方面:需求获取、需求分析、编写需求规格说明书以及______。(B)
A. 阶段性报告 B. 需求评审 C. 总结 D. 都不正确
(8) 下述关于数据库系统的叙述中正确的是______。(A)
A. 数据库系统减少了数据冗余
B. 数据库系统避免了一切冗余
C. 数据库系统中数据的一致性是指数据类型的一致
D. 数据库系统比文件系统能管理更多的数据
(9) 关系表中的每一横行称为一个______。(A)
A. 元组 B. 字段 C. 属性 D. 码
(10) 数据库设计包括两个方面的设计内容,它们是______。(A)
A. 概念设计和逻辑设计 B. 模式设计和内模式设计
C. 内模式设计和物理设计 D. 结构特性设计和行为特性设计
(1) 算法的空间复杂度是指______。(D)
A. 算法程序的长度 B. 算法程序中的指令条数
C. 算法程序所占的存储空间 D. 算法执行过程中所需要的存储空间
(2) 下列关于栈的叙述中正确的是______。(D)
A. 在栈中只能插入数据 B. 在栈中只能删除数据
C. 栈是先进先出的线性表 D. 栈是先进后出的线性表
(3) 在深度为5的满二叉树中,叶子结点的个数为______。(C)
A. 32 B. 31 C. 16 D. 15
(4) 对建立良好的程序设计风格,下面描述正确的是______。(A)
A. 程序应简单、清晰、可读性好 B. 符号名的命名要符合语法
C. 充分考虑程序的执行效率 D. 程序的注释可有可无
(5) 下面对对象概念描述错误的是______。(A)
A. 任何对象都必须有继承性 B. 对象是属性和方法的封装体
C. 对象间的通讯靠消息传递 D. 操作是对象的动态性属性
(6) 下面不属于软件工程的3个要素的是______。(D)
A. 工具 B. 过程 C. 方法 D. 环境
(7) 程序流程图(PFD)中的箭头代表的是______。(B)
A. 数据流 B. 控制流 C. 调用关系 D. 组成关系
(8) 在数据管理技术的发展过程中,经历了人工管理阶段、文件系统阶段和数据库系统阶段。其中数据独立性最高的阶段是______。(A)
A. 数据库系统 B. 文件系统 C. 人工管理 D. 数据项管理
(9) 用树形结构来表示实体之间联系的模型称为______。(B)
A. 关系模型 B. 层次模型 C. 网状模型 D. 数据模型
(10) 关系数据库管理系统能实现的专门关系运算包括______。(B)
A. 排序、索引、统计 B. 选择、投影、连接
C. 关联、更新、排序 D. 显示、打印、制表
(1) 算法一般都可以用哪几种控制结构组合而成______。(D)
A. 循环、分支、递归 B. 顺序、循环、嵌套
C. 循环、递归、选择 D. 顺序、选择、循环
(2) 数据的存储结构是指______。(B)
A. 数据所占的存储空间量 B. 数据的逻辑结构在计算机中的表示
C. 数据在计算机中的顺序存储方式 D. 存储在外存中的数据
(3) 在面向对象方法中,一个对象请求另一对象为其服务的方式是通过发送______。(D)
A. 调用语句 B. 命令 C. 口令 D. 消息
(4) 检查软件产品是否符合需求定义的过程称为______。(A)
A. 确认测试 B. 集成测试 C. 验证测试 D. 验收测试
(5) 下列工具中属于需求分析常用工具的是______。(D)
A. PFD B. PAD (问题分析图:problem analysis diagram) C. N-S D. DFD(数据流程图)
(6) 下面不属于软件设计原则的是______。(C)
A. 抽象 B. 模块化 C. 自底向上 D. 信息隐蔽
(7) 索引属于______。(B)
A. 模式 B. 内模式 C. 外模式 D. 概念模式
(8) 在关系数据库中,用来表示实体之间联系的是______。(D)
A. 树结构B. 网结构C. 线性表 D. 二维表
(9) 将E-R图转换到关系模式时,实体与联系都可以表示成______。(B)
A. 属性 B. 关系 C. 键 D. 域
2009年上半年全国计算机等级考试你准备好了没?考计算机等级二级考试的朋友,2009年上半年全国计算机等级考试时间是2009年3月28日到4月1日。考试大为大家整理的2009年上半年全国计算机等级二级公共基础知识考前练习!希望对大家的备考有好的帮助!考试大祝各位考个好成绩!
(1) 在下列选项中,哪个不是一个算法一般应该具有的基本特征______。(C)
A. 确定性 B. 可行性 C. 无穷性 D. 拥有足够的情报
(2) 希尔排序法属于哪一种类型的排序法______。(B)
A. 交换类排序法 B. 插入类排序法 C. 选择类排序法 D. 建堆排序法
(3) 下列关于队列的叙述中正确的是______。(C)
A. 在队列中只能插入数据(队尾) B. 在队列中只能删除数据(对首)
C. 队列是先进先出(FIFO)的线性表 D. 队列是先进后出的线性表
(4) 对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为______。(B)
A. N+1 B. N C. (N+1)/2 D. N/2
(5) 信息隐蔽的概念与下述哪一种概念直接相关______。(B)
A. 软件结构定义 B. 模块独立性 C. 模块类型划分 D. 模拟耦合度
(6) 面向对象的设计方法与传统的的面向过程的方法有本质不同,它的基本原理是______。(C)
A. 模拟现实世界中不同事物之间的联系
B. 强调模拟现实世界中的算法而不强调概念
C. 使用现实世界的概念抽象地思考问题从而自然地解决问题
D. 鼓励开发者在软件开发的绝大部分中都用实际领域的概念去思考
(7) 在结构化方法中,软件功能分解属于下列软件开发中的阶段是______。(C)
A. 详细设计 B. 需求分析 C. 总体设计 D. 编程调试
(8) 软件调试的目的是______。(B)
A. 发现错误 B. 改正错误 C. 改善软件的性能 D. 挖掘软件的潜能
(9) 按条件f对关系R进行选择,其关系代数表达式为______。(C)
A. R|X|R B. R|X|R C. бf(R) D. ∏f(R)
(10) 数据库概念设计的过程中,视图设计一般有三种设计次序,以下各项中不对的是______。(D)
A. 自顶向下 B. 由底向上 C. 由内向外 D. 由整体到局部
(1) 在计算机中,算法是指______。(C)
A. 查询方法 B. 加工方法 C. 解题方案的准确而完整的描述 D. 排序方法
(2) 栈和队列的共同点是______。(C)
A. 都是先进后出 B. 都是先进先出 C. 只允许在端点处插入和删除元素 D. 没有共同点
(3) 已知二叉树后序遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是______。(A)
A. cedba B. acbed C. decab D. deabc
(4) 在下列几种排序方法中,要求内存量最大的是______。(D)
A. 插入排序 B. 选择排序 C. 快速排序 D. 归并排序
(5) 在设计程序时,应采纳的原则之一是______。(A)
A. 程序结构应有助于读者理解 B. 不限制goto语句的使用
C. 减少或取消注解行 D. 程序越短越好
(6) 下列不属于软件调试技术的是______。(B)
A. 强行排错法 B. 集成测试法 C. 回溯法 D. 原因排除法
(7) 下列叙述中,不属于软件需求规格说明书的作用的是______。(D)
A. 便于用户、开发人员进行理解和交流
B. 反映出用户问题的结构,可以作为软件开发工作的基础和依据
C. 作为确认测试和验收的依据
D. 便于开发人员进行需求分析
(8) 在数据流图(DFD)中,带有名字的箭头表示______。(C)
A. 控制程序的执行顺序 B. 模块之间的调用关系
C. 数据的流向 D. 程序的组成成分
(9) SQL语言又称为______。(C)
A. 结构化定义语言 B. 结构化控制语言
C. 结构化查询语言 D. 结构化操纵语言
(10) 视图设计一般有3种设计次序,下列不属于视图设计的是______。(B)
A. 自顶向下 B. 由外向内 C. 由内向外 D. 自底向上
(1) 数据结构中,与所使用的计算机无关的是数据的______。(C)
A. 存储结构 B. 物理结构 C. 逻辑结构 D. 物理和存储结构
(2) 栈底至栈顶依次存放元素A、B、C、D,在第五个元素E入栈前,栈中元素可以出栈,则出栈序列可能是______。(D)
A. ABCED B. DBCEA C. CDABE D. DCBEA
(3) 线性表的顺序存储结构和线性表的链式存储结构分别是______。(B)
A. 顺序存取的存储结构、顺序存取的存储结构
B. 随机存取的存储结构、顺序存取的存储结构
C. 随机存取的存储结构、随机存取的存储结构
D. 任意存取的存储结构、任意存取的存储结构
(4) 在单链表中,增加头结点的目的是______。(A)
A. 方便运算的实现
B. 使单链表至少有一个结点
C. 标识表结点中首结点的位置
D. 说明单链表是线性表的链式存储实现
(5) 软件设计包括软件的结构、数据接口和过程设计,其中软件的过程设计是指______。(B)
A. 模块间的关系
B. 系统结构部件转换成软件的过程描述
C. 软件层次结构
D. 软件开发过程
(6) 为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种图称为______。(B)
A. PAD图 B. N-S图 C. 结构图 D. 数据流图
(7) 数据处理的最小单位是______。(C)
A. 数据 B. 数据元素 C. 数据项 D. 数据结构
(8) 下列有关数据库的描述,正确的是______。(C)
A. 数据库是一个DBF文件
B. 数据库是一个关系
C. 数据库是一个结构化的数据集合
D. 数据库是一组文件
(9) 单个用户使用的数据视图的描述称为______。(A)
A. 外模式 B. 概念模式 C. 内模式 D. 存储模式
(10) 需求分析阶段的任务是确定______。(D)
A. 软件开发方法 B. 软件开发工具 C. 软件开发费用 D. 软件系统功能
(1) 算法分析的目的是______。(D)
A. 找出数据结构的合理性
B. 找出算法中输入和输出之间的关系
C. 分析算法的易懂性和可靠性
D. 分析算法的效率以求改进
(2) n个顶点的强连通图的边数至少有______。(C)
A. n-1 B. n(n-1) C. n D. n+1
(3) 已知数据表A中每个元素距其最终位置不远,为节省时间,应采用的算法是______。(B)
A. 堆排序 B. 直接插入排序 C. 快速排序 D. 直接选择排序
(4) 用链表表示线性表的优点是______。(A)
A. 便于插入和删除操作
B. 数据元素的物理顺序与逻辑顺序相同
C. 花费的存储空间较顺序存储少
D. 便于随机存取
(5) 下列不属于结构化分析的常用工具的是______。(D)
A. 数据流图 B. 数据字 C. 判定树 D. PAD图结构化分析的常用工具
(6) 软件开发的结构化生命周期方法将软件生命周期划分成______。(A)
A. 定义、开发、运行维护
B. 设计阶段、编程阶段、测试阶段
C. 总体设计、详细设计、编程调试
D. 需求分析、功能定义、系统设计
(7) 在软件工程中,白箱测试法可用于测试程序的内部结构。此方法将程序看做是______。(C)
A. 循环的集合 B. 地址的集合 C. 路径的集合 D. 目标的集合
(8) 在数据管理技术发展过程中,文件系统与数据库系统的主要区别是数据库系统具有______。(D) 结构化查询语句:SQL
A. 数据无冗余 B. 数据可共享 C. 专门的数据管理软件 D. 特定的数据模型
(9) 分布式数据库系统不具有的特点是______。(B)
A. 分布式 B. 数据冗余
C. 数据分布性和逻辑整体性 D. 位置透明性和复制透明性
(10) 下列说法中,不属于数据模型所描述的内容的是______。(C)
A. 数据结构 B. 数据操作 C. 数据查询 D. 数据约束
1) 算法的复杂度主要包括__时间____复杂度和空间复杂度。
答:时间
(2) 数据的逻辑结构在计算机存储空间中的存放形式称为数据的_逻辑模式_____。
答:模式#逻辑模式#概念模式
(3) 若按功能划分,软件测试的方法通常分为白盒测试方法和___黑盒___测试方法。
答:黑盒
(4) 如果一个工人可管理多个设施,而一个设施只被一个工人管理,则实体"工人"与实体"设备"之间存在___1:n___联系。
答:一对多#1:N#1:n
(5) 关系数据库管理系统能实现的专门关系运算包括选择、连接和______。
答:投影
(6) 在先左后右的原则下,根据访问根结点的次序,二叉树的遍历可以分为三种:前序遍历、______遍历和后序遍历。
答:中序
(7) 结构化程序设计方法的主要原则可以概括为自顶向下、逐步求精、___模块化___和限制使用goto语句。
答:模块化
(8) 软件的调试方法主要有:强行排错法、______和原因排除法。
答:回溯法
(9) 数据库系统的三级模式分别为______模式、内部级模式与外部级模式。
答:概念#概念级
(10) 数据字典是各类数据描述的集合,它通常包括5个部分,即数据项、数据结构、数据流、______和处理过程。
答:数据存储
(1) 设一棵完全二叉树共有500个结点,则在该二叉树中有______个叶子结点。
答:250
(2) 在最坏情况下,冒泡排序的时间复杂度为______。
答:n(n-1)/2#n*(n-1)/2#O(n(n-1)/2)#O(n*(n-1)/2)
(3) 面向对象的程序设计方法中涉及的对象是系统中用来描述客观事物的一个______。
答:实体
(4) 软件的需求分析阶段的工作,可以概括为四个方面:______、需求分析、编写需求规格说明书和需求评审。
答:需求获取
(5) ___数据库设计___是数据库应用的核心。
答:数据库设计
(6) 数据结构包括数据的______结构和数据的存储结构。
答:逻辑
(7) 软件工程研究的内容主要包括:______技术和软件工程管理。
答:软件开发
(8) 与结构化需求分析方法相对应的是______方法。
答:结构化设计
(9) 关系模型的完整性规则是对关系的某种约束条件,包括实体完整性、______和自定义完整性。
答:参照完整性
(10) 数据模型按不同的应用层次分为三种类型,它们是______数据模型、逻辑数据模型和物理数据模型。
答:概念
(1) 栈的基本运算有三种:入栈、退栈和______。
答:读栈顶元素#读栈顶的元素#读出栈顶元素
(2) 在面向对象方法中,信息隐蔽是通过对象的______性来实现的。
答:封装
(3) 数据流的类型有______和事务型。
答:变换型
(4) 数据库系统中实现各种数据管理功能的核心软件称为______。
答:数据库管理系统#DBMS
(5) 关系模型的数据操纵即是建立在关系上的数据操纵,一般有______、增加、删除和修改四种操作。
答:查询
(6) 实现算法所需的存储单元多少和算法的工作量大小分别称为算法的 ______。
答:空间复杂度和时间复杂度
(7) 数据结构包括数据的逻辑结构、数据的 ______以及对数据的操作运算。
答:存储结构
(8) 一个类可以从直接或间接的祖先中继承所有属性和方法。采用这个方法提高了软件的______。
答:可重用性
(9) 面向对象的模型中,最基本的概念是对象和 ______。
答:类
(10) 软件维护活动包括以下几类:改正性维护、适应性维护、______维护和预防性维护。
答:完善性
(1) 算法的基本特征是可行性、确定性、______和拥有足够的情报。
答:有穷性
(2) 顺序存储方法是把逻辑上相邻的结点存储在物理位置______的存储单元中。
答:相邻
(3) Jackson结构化程序设计方法是英国的M.Jackson提出的,它是一种面向__数据结构____的设计方法。
答:
(4) 数据库设计分为以下6个设计阶段:需求分析阶段、___概念设计阶段#数据库概念设计阶段___、逻辑设计阶段、物理设计阶段、实施阶段、运行和维护阶段。
答:
(5) 数据库保护分为:安全性控制 、__完整性控制____、并发性控制和数据的恢复。
答:
(6) 测试的目的是暴露错误,评价程序的可靠性;而___调试___的目的是发现错误的位置并改正错误。
答:
(7) 在最坏情况下,堆排序需要比较的次数为___ O(nlog2n)___。
答:
(8) 若串s="Program",则其子串的数目是___29___。
答:
(9) 一个项目具有一个项目主管,一个项目主管可管理多个项目,则实体"项目主管"与实体"项目"的联系属于___1对多#1:N___的联系。
(10) 数据库管理系统常见的数据模型有层次模型、网状模型和关系模型三种。
(1) 下面叙述正确的是______。(C)
A. 算法的执行效率与数据的存储结构无关
B. 算法的空间复杂度是指算法程序中指令(或语句)的条数
C. 算法的有穷性是指算法必须能在执行有限个步骤之后终止
D. 以上三种描述都不对
(2) 以下数据结构中不属于线性数据结构的是______。(C)
A. 队列
B. 线性表
C. 二叉树
D. 栈
(3) 在一棵二叉树上第5层的结点数最多是______。(B)
A. 8
B. 16
C. 32
D. 15
(4) 下面描述中,符合结构化程序设计风格的是______。(A)
A. 使用顺序、选择和重复(循环)三种基本控制结构表示程序的控制逻辑
B. 模块只有一个入口,可以有多个出口
C. 注重提高程序的执行效率
D. 不使用goto语句
(5) 下面概念中,不属于面向对象方法的是______。(D)
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. 数据库是一个独立的系统,不需要操作系统的支持
B. 数据库设计是指设计数据库管理系统
C. 数据库技术的根本目标是要解决数据共享的问题
D. 数据库系统中,数据的物理结构必须与逻辑结构一致
(10) 下列模式中,能够给出数据库物理存储结构与物理存取方法的是______。(A)
A. 内模式
B. 外模式
C. 概念模式
D. 逻辑模式
(11) 算法的时间复杂度是指______。(C)
A. 执行算法程序所需要的时间
B. 算法程序的长度
C. 算法执行过程中所需要的基本运算次数
D. 算法程序中的指令条数
(12) 下列叙述中正确的是______。(A)
A. 线性表是线性结构
B. 栈与队列是非线性结构
C. 线性链表是非线性结构
D. 二叉树是线性结构
(13) 设一棵完全二叉树共有699个结点,则在该二叉树中的叶子结点数为______。(B)
A. 349
B. 350
C. 255
D. 351
(14) 结构化程序设计主要强调的是______。(B)
A. 程序的规模
B. 程序的易读性
C. 程序的执行效率
D. 程序的可移植性
(15) 在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段是______。(D)
A. 概要设计
B. 详细设计
C. 可行性分析
D. 需求分析
(16) 数据流图用于抽象描述一个软件的逻辑模型,数据流图由一些特定的图符构成。下列图符名标识的图符不属于数据流图合法图符的是______。(A)
A. 控制流
B. 加工
C. 数据存储
D. 源和潭
(17) 软件需求分析阶段的工作,可以分为四个方面:需求获取、需求分析、编写需求规格说明书以及______。(B)
A. 阶段性报告
B. 需求评审
C. 总结
D. 都不正确
(18) 下述关于数据库系统的叙述中正确的是______。(A)
A. 数据库系统减少了数据冗余
B. 数据库系统避免了一切冗余
C. 数据库系统中数据的一致性是指数据类型的一致
D. 数据库系统比文件系统能管理更多的数据
(19) 关系表中的每一横行称为一个______。(A)
A. 元组
B. 字段
C. 属性
D. 码
(20) 数据库设计包括两个方面的设计内容,它们是______。(A)
A. 概念设计和逻辑设计
B. 模式设计和内模式设计
C. 内模式设计和物理设计
D. 结构特性设计和行为特性设计
(21) 算法的空间复杂度是指______。(D)
A. 算法程序的长度
B. 算法程序中的指令条数
C. 算法程序所占的存储空间
D. 算法执行过程中所需要的存储空间
(22) 下列关于栈的叙述中正确的是______。(D)
A. 在栈中只能插入数据
B. 在栈中只能删除数据
C. 栈是先进先出的线性表
D. 栈是先进后出的线性表
(23) 在深度为5的满二叉树中,叶子结点的个数为______。(C)
A. 32
B. 31
C. 16
D. 15
(24) 对建立良好的程序设计风格,下面描述正确的是______。(A)
A. 程序应简单、清晰、可读性好
B. 符号名的命名要符合语法
C. 充分考虑程序的执行效率
D. 程序的注释可有可无
(25) 下面对对象概念描述错误的是______。(A)
A. 任何对象都必须有继承性
B. 对象是属性和方法的封装体
C. 对象间的通讯靠消息传递
D. 操作是对象的动态性属性
(26) 下面不属于软件工程的3个要素的是______。(D)
A. 工具
B. 过程
C. 方法
D. 环境
(27) 程序流程图(PFD)中的箭头代表的是______。(B)
A. 数据流
B. 控制流
C. 调用关系
D. 组成关系
(28) 在数据管理技术的发展过程中,经历了人工管理阶段、文件系统阶段和数据库系统阶段。其中数据独立性最高的阶段是______。(A)
A. 数据库系统
B. 文件系统
C. 人工管理
D. 数据项管理
(29) 用树形结构来表示实体之间联系的模型称为______。(B)
A. 关系模型
B. 层次模型
C. 网状模型
D. 数据模型
(30) 关系数据库管理系统能实现的专门关系运算包括______。(B)
A. 排序、索引、统计
B. 选择、投影、连接
C. 关联、更新、排序
D. 显示、打印、制表
(31) 算法一般都可以用哪几种控制结构组合而成______。(D)
A. 循环、分支、递归
B. 顺序、循环、嵌套
C. 循环、递归、选择
D. 顺序、选择、循环
(32) 数据的存储结构是指______。(B)
A. 数据所占的存储空间量
B. 数据的逻辑结构在计算机中的表示
C. 数据在计算机中的顺序存储方式
D. 存储在外存中的数据
(33) 设有下列二叉树:
对此二叉树中序遍历的结果为______。(B)
A. ABCDEF
B. DBEAFC
C. ABDECF
D. DEBFCA
(34) 在面向对象方法中,一个对象请求另一对象为其服务的方式是通过发送______。(D)
A. 调用语句 B. 命令
C. 口 令 D. 消息
(35) 检查软件产品是否符合需求定义的过程称为______。(A)
A. 确认测试
B. 集成测试
C. 验证测试
D. 验收测试
(36) 下列工具中属于需求分析常用工具的是______。(D)
A. 
AD
B. 
FD
C. N-S
D. DFD
(37) 下面不属于软件设计原则的是______。(C)
A. 抽象
B. 模块化
C. 自底向上
D. 信息隐蔽
(38) 索引属于______。(B)
A. 模式
B. 内模式
C. 外模式
D. 概念模式
(39) 在关系数据库中,用来表示实体之间联系的是______。(D)
A. 树结构
B. 网结构
C. 线性表
D. 二维表
(40) 将E-R图转换到关系模式时,实体与联系都可以表示成__ A.关系____
A.关系 B. 键 C. 域
(41) 在下列选项中,哪个不是一个算法一般应该具有的基本特征______。(C)
A. 确定性
B. 可行性
C. 无穷性
D. 拥有足够的情报
42) 希尔排序法属于哪一种类型的排序法______。(B)
A. 交换类排序法
B. 插入类排序法
C. 选择类排序法
D. 建堆排序法
(43) 下列关于队列的叙述中正确的是______。(C)
A. 在队列中只能插入数据
B. 在队列中只能删除数据
C. 队列是先进先出的线性表
D. 队列是先进后出的线性表
(44) 对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为______。(B)
A. N+1
B. N
C. (N+1)/2
D. N/2
(45) 信息隐蔽的概念与下述哪一种概念直接相关______。(B)
A. 软件结构定义
B. 模块独立性
C. 模块类型划分
D. 模拟耦合度
(46) 面向对象的设计方法与传统的的面向过程的方法有本质不同,它的基本原理是______。(C)
A. 模拟现实世界中不同事物之间的联系
B. 强调模拟现实世界中的算法而不强调概念
C. 使用现实世界的概念抽象地思考问题从而自然地解决问题
D. 鼓励开发者在软件开发的绝大部分中都用实际领域的概念去思考
(47) 在结构化方法中,软件功能分解属于下列软件开发中的阶段是______。(C)
A. 详细设计
B. 需求分析
C. 总体设计
D. 编程调试
(48) 软件调试的目的是______。(B)
A. 发现错误
B. 改正错误
C. 改善软件的性能
D. 挖掘软件的潜能
(49) 按条件f对关系R进行选择,其关系代数表达式为______。(C)
A. R|X|R
B. R|X|R f
C. бf(R)
D. ∏f(R)
(50) 数据库概念设计的过程中,视图设计一般有三种设计次序,以下各项中不对的是______。(D)
A. 自顶向下
B. 由底向上
C. 由内向外
D. 由整体到局部
(51) 在计算机中,算法是指______。(C)
A. 查询方法
B. 加工方法
C. 解题方案的准确而完整的描述
D. 排序方法
(52) 栈和队列的共同点是______。(C)
A. 都是先进后出
B. 都是先进先出
C. 只允许在端点处插入和删除元素
D. 没有共同点
(53) 已知二叉树后序遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是______。(A)
A. cedba
B. acbed
C. decab
D. deabc
(54) 在下列几种排序方法中,要求内存量最大的是______。(D)
A. 插入排序
B. 选择排序
C. 快速排序
D. 归并排序
(55) 在设计程序时,应采纳的原则之一是______。(A)
A. 程序结构应有助于读者理解
B. 不限制goto语句的使用
C. 减少或取消注解行
D. 程序越短越好
(56) 下列不属于软件调试技术的是______。(B)
A. 强行排错法
B. 集成测试法
C. 回溯法
D. 原因排除法
(57) 下列叙述中,不属于软件需求规格说明书的作用的是______。(D)
A. 便于用户、开发人员进行理解和交流
B. 反映出用户问题的结构,可以作为软件开发工作的基础和依据
C. 作为确认测试和验收的依据
D. 便于开发人员进行需求分析
(58) 在数据流图(DFD)中,带有名字的箭头表示______。(C)
A. 控制程序的执行顺序
B. 模块之间的调用关系
C. 数据的流向
D. 程序的组成成分
(59) SQL语言又称为______。(C)
A. 结构化定义语言
B. 结构化控制语言
C. 结构化查询语言
D. 结构化操纵语言
(60) 视图设计一般有3种设计次序,下列不属于视图设计的是______。(B)
A. 自顶向下
B. 由外向内
C. 由内向外
D. 自底向上
(61) 数据结构中,与所使用的计算机无关的是数据的______。(C)
A. 存储结构
B. 物理结构
C. 逻辑结构
D. 物理和存储结构
(62) 栈底至栈顶依次存放元素A、B、C、D,在第五个元素E入栈前,栈中元素可以出栈,则出栈序列可能是______。(D)
A. ABCED
B. DBCEA
C. CDABE
D. DCBEA
(63) 线性表的顺序存储结构和线性表的链式存储结构分别是______。(B)
A. 顺序存取的存储结构、顺序存取的存储结构
B. 随机存取的存储结构、顺序存取的存储结构
C. 随机存取的存储结构、随机存取的存储结构
D. 任意存取的存储结构、任意存取的存储结构
(64) 在单链表中,增加头结点的目的是______。(A)
A. 方便运算的实现
B. 使单链表至少有一个结点
C. 标识表结点中首结点的位置
D. 说明单链表是线性表的链式存储实现
(65) 软件设计包括软件的结构、数据接口和过程设计,其中软件的过程设计是指______。(B)
A. 模块间的关系
B. 系统结构部件转换成软件的过程描述
C. 软件层次结构
D. 软件开发过程
(66) 为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种图称为______。(B)
A. 
AD图
B. N-S图
C. 结构图
D. 数据流图
(67) 数据处理的最小单位是______。(C)
A. 数据
B. 数据元素
C. 数据项
D. 数据结构
(68) 下列有关数据库的描述,正确的是______。(C)
A. 数据库是一个DBF文件
B. 数据库是一个关系
C. 数据库是一个结构化的数据集合
D. 数据库是一组文件
(69) 单个用户使用的数据视图的描述称为______。(A)
A. 外模式
B. 概念模式
C. 内模式
D. 存储模式
(70) 需求分析阶段的任务是确定______。(D)
A. 软件开发方法
B. 软件开发工具
C. 软件开发费用
D. 软件系统功能
(71) 算法分析的目的是______。(D)
A. 找出数据结构的合理性
B. 找出算法中输入和输出之间的关系
C. 分析算法的易懂性和可靠性
D. 分析算法的效率以求改进
(72) n个顶点的强连通图的边数至少有______。(C)
A. n-1
B. n(n-1)
C. n
D. n+1
(73) 已知数据表A中每个元素距其最终位置不远,为节省时间,应采用的算法是______。(B)
A. 堆排序
B. 直接插入排序
C. 快速排序
D. 直接选择排序
(74) 用链表表示线性表的优点是______。(A)
A. 便于插入和删除操作
B. 数据元素的物理顺序与逻辑顺序相同
C. 花费的存储空间较顺序存储少
D. 便于随机存取
(75) 下列不属于结构化分析的常用工具的是______。(D)
A. 数据流图
B. 数据字典
C. 判定树
D. PAD图
(76) 软件开发的结构化生命周期方法将软件生命周期划分成______。(A)
A. 定义、开发、运行维护
B. 设计阶段、编程阶段、测试阶段
C. 总体设计、详细设计、编程调试
D. 需求分析、功能定义、系统设计
(77) 在软件工程中,白箱测试法可用于测试程序的内部结构。此方法将程序看做是______。(C)
A. 循环的集合
B. 地址的集合
C. 路径的集合
D. 目标的集合
(78) 在数据管理技术发展过程中,文件系统与数据库系统的主要区别是数据库系统具有______。(D)
A. 数据无冗余
B. 数据可共享
C. 专门的数据管理软件
D. 特定的数据模型
(79) 分布式数据库系统不具有的特点是______。(B)
A. 分布式
B. 数据冗余
C. 数据分布性和逻辑整体性
D. 位置透明性和复制透明性
(80) 下列说法中,不属于数据模型所描述的内容的是______。(C)
A. 数据结构
B. 数据操作
C. 数据查询
D. 数据约束
(1) 算法的复杂度主要包括__时间____复杂度和空间复杂度。
答:时间
(2) 数据的逻辑结构在计算机存储空间中的存放形式称为数据的___逻辑模式___。
答:模式#逻辑模式#概念模式
(3) 若按功能划分,软件测试的方法通常分为白盒测试方法和___黑盒___测试方法。
答:黑盒
(4) 如果一个工人可管理多个设施,而一个设施只被一个工人管理,则实体"工人"与实体"设备"之间存在______联系。
答:一对多#1:N#1:n
(5) 关系数据库管理系统能实现的专门关系运算包括选择、连接和__投影____。
答:投影
(6) 在先左后右的原则下,根据访问根结点的次序,二叉树的遍历可以分为三种:前序遍历、______遍历和后序遍历。
答:中序
(7) 结构化程序设计方法的主要原则可以概括为自顶向下、逐步求精、______和限制使用goto语句。
答:模块化
(8) 软件的调试方法主要有:强行排错法、___回溯法___和原因排除法。
答:回溯法
(9) 数据库系统的三级模式分别为______模式、内部级模式与外部级模式。
答:概念#概念级
(10) 数据字典是各类数据描述的集合,它通常包括5个部分,即数据项、数据结构、数据流、______和处理过程。
答:数据存储
(11) 设一棵完全二叉树共有500个结点,则在该二叉树中有______个叶子结点。
答:250
(12) 在最坏情况下,冒泡排序的时间复杂度为______。
答:n(n-1)/2#n*(n-1)/2#O(n(n-1)/2)#O(n*(n-1)/2)
(13)面向对象的程序设计方法中涉及的对象是系统中用来描述客观事物的一个______。
答:实体
(14) 软件的需求分析阶段的工作,可以概括为四个方面:______、需求分析、编写需求规格说明书和需求评审。
答:需求获取
(15) ______是数据库应用的核心。
答:数据库设计
(16) 数据结构包括数据的______结构和数据的存储结构。
答:逻辑
(17) 软件工程研究的内容主要包括:______技术和软件工程管理。
答:软件开发
(18) 与结构化需求分析方法相对应的是______方法。
答:结构化设计
(19) 关系模型的完整性规则是对关系的某种约束条件,包括实体完整性、___参照完整性___和自定义完整性。
答:参照完整性
(20) 数据模型按不同的应用层次分为三种类型,它们是______数据模型、逻辑数据模型和物理数据模型。
答:概念
(21) 栈的基本运算有三种:入栈、退栈和______。
答:读栈顶元素#读栈顶的元素#读出栈顶元素
(22) 在面向对象方法中,信息隐蔽是通过对象的______性来实现的。
答:封装
(23) 数据流的类型有____变换型__和事务型。
答:变换型
(24) 数据库系统中实现各种数据管理功能的核心软件称为______。
答:数据库管理系统#DBMS
(25) 关系模型的数据操纵即是建立在关系上的数据操纵,一般有______、增加、删除和修改四种操作。
答:查询
(26) 实现算法所需的存储单元多少和算法的工作量大小分别称为算法的 ______。
答:空间复杂度和时间复杂度
(27) 数据结构包括数据的逻辑结构、数据的 ______以及对数据的操作运算。
答:存储结构
(28) 一个类可以从直接或间接的祖先中继承所有属性和方法。采用这个方法提高了软件的__可重用性____。
答:可重用性
(29) 面向对象的模型中,最基本的概念是对象和 __类____。
答:类
(30) 软件维护活动包括以下几类:改正性维护、适应性维护、______维护和预防性维护。
答:完善性
(31) 算法的基本特征是可行性、确定性、___有穷性___和拥有足够的情报。
答:有穷性
(32) 顺序存储方法是把逻辑上相邻的结点存储在物理位置______的存储单元中。
答:相邻
(33) Jackson结构化程序设计方法是英国的M.Jackson提出的,它是一种面向______的设计方法。
答:数据结构
(34) 数据库设计分为以下6个设计阶段:需求分析阶段、______、逻辑设计阶段、物理设计阶段、实施阶段、运行和维护阶段。
答:概念设计阶段#数据库概念设计阶段
(35) 数据库保护分为:安全性控制 、______、并发性控制和数据的恢复。
答:完整性控制
(36) 测试的目的是暴露错误,评价程序的可靠性;而__调试____的目的是发现错误的位置并改正错误。
答:调试
(37) 在最坏情况下,堆排序需要比较的次数为______。
答:O(nlog2n)
(38) 若串s="Program",则其子串的数目是______。
答:29
(39) 一个项目具有一个项目主管,一个项目主管可管理多个项目,则实体"项目主管"与实体"项目"的联系属于______的联系。
答:1对多#1:N
(40) 数据库管理系统常见的数据模型有层次模型、网状模型和______三种。
答:关系模型
Prt
左移运算符a<<n:前面的数字a除以2的n次方;
右移运算符a>>n:前面的数字a乘以2的n次方;
For,while,do……while循环分别运行几次?
For从初始值开始循环;while先判断,从初始值开始循环;do……while先循环,出初始值开始循环。
Switch语句:
出进栈的规则:
Fscabf(文件指针,格式字符串,输入列表);
函数:实参与形参
表达式的要求
宏定义的变量不能运算
深度,叶子结点数
数据模型:
语句需要有“;”
Strlen()是什么意思?
数据库概念设计过程:选择局部应用;局部视图设计;视图集成
数据库设计的基本任务是根据用户对象信息需求,处理需求和数据库的支持环境设计出数据模式
消息的组成包括:接受消息的对象名称;消息标识符;相应的参数
黑盒测试(功能测试或者数据驱动测试):等价分类法;边缘值分析法;因果图法;错误推测法
常见的过程设计工具---软件开发详细设计阶段:
图形工具:程序流程图;N-S;PDA(问题分析图);HIPO
表格工具:判定表
语言工具:PDL(过程设计语言)(伪码)
结构化分析常见工具---软件开发需求分析阶段:
DFD(数据流图);DD(数据字典);判定树;判定表
N-S:程序化设计的方框图
数据库的三级模式:概念模式;内模式;外模式
现实世界----概念世界(信息世界)E-R实体联系模型---机器世界(存储世界或者数据世界)
数据库的组成:硬件系统;数据库集合;系统软件;数据库管理员;用户
数据模型:层次模型;网状模型;关系模型;面向对象模型
(至少包括数据结构,数据操作,数据完整性)
Front>rear n-front+rear
Front<rear rear-front
结构化程序设计方法的主要原则:
自顶向下;逐步求精;模块化;限制使用goto语句
结构良好,易读,易理解,易维护
模块独立性中。内聚程度与耦合程度关系其强弱!
功能内聚,内容耦合,则独立性弱;
偶然内聚,非直接耦合,则独立性强;
算法的特点:有穷性;确定性;可行性;输入;输出
fseek(文件指针,位移量,起始点)
fread()
fopen(文件名,使用文件方式)
打开文件;调用方式 FILE *fp
fwrite()
fprintf(文件指针,格式字符串,输出列表)
传送格式化输出到另一个文件
Fclose(文件指针)
关闭文件
Fscnf(文件指针,格式字符串,输出列表)
从磁盘文件执行格式化输入
软件设计原则:抽象;模块化;,信息隐蔽;数据独立性
数据库设计的两个方面:概念与逻辑设计
数据库设计的6个阶段:需求分析阶段;概念设计阶段;逻辑设计阶段;物理设计阶段;实施阶段;数据库运行与维护阶段
对象的基本特征:标志唯一性;分类型;多态性;封装性;模块独立性
数据模型是数据库设计的核心