全国计算机二级C语言 - 公共基础120题详解

更新时间:2024-05-06 05:09:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

公共基础知识120题详解篇

(1) 下面叙述正确的是______。 A. 算法的执行效率与数据的存储结构无关

B. 算法的空间复杂度是指算法程序中指令(或语句)的条数 C. 算法的有穷性是指算法必须能在执行有限个步骤之后终止 D. 以上三种描述都不对 (1) [答案]C

[考点]程序设计基础 [评析]

时间复杂度:在运行算法时所耗费的时间为f(n)(即 n的函数)。 空间复杂度:实现算法所占用的空间为g(n)(也为n的函数)。 A应为有关。

(2) 以下数据结构中不属于线性数据结构的是______。 A. 队列 B. 线性表 C. 二叉树 D. 栈 (2) [答案]C

[考点]数据结构与算法 [评析]

一棵二叉树的一个结点下面可以有2个子结点,故不是线性结构(通俗地理解,看是否能排成条直线)。

A是先进先出的线性表;B是宏观概念,包括顺序表、链表、堆栈、队列…;D是先进后出的线性表

(3) 在一棵二叉树上第5层的结点数最多是______。 A. 8 B. 16

Page 1 of 51

C. 32 D. 15 (3) [答案]B

[考点]数据结构与算法 [评析]依次从上到下,可得出: 第1层结点数为1; 第2层结点数为2*1=2; 第3层结点数为2*2=4;

第n层结点数为2的n-1次幂,如图所示

(4) 下面描述中,符合结构化程序设计风格的是______。

A. 使用顺序、选择和重复(循环)三种基本控制结构表示程序的控制逻辑 B. 模块只有一个入口,可以有多个出口 C. 注重提高程序的执行效率 D. 不使用goto语句 (4) [答案]A

[考点]程序设计基础 [评析]

B没这规定,模块之间的可以通过多个接口来耦合

C结构化程序设计提倡程序的可读性(可理解性),超过程序执行效率的要求 D结构化程序设计限制goto语句的使用,因为goto语句的功能可以用三种基本的控制结构来代替,但也不是绝对不能用,只是限制使用(少用)。 (5) 下面概念中,不属于面向对象方法的是______。 A. 对象 B. 继承 C. 类 D. 过程调用

Page 2 of 51

(5) [答案]D

[考点]软件工程基础 [评析]

面向对象=对象+类+继承+通过消息的通信 对象:一组属性及其上的操作的封装体 类:一组有相同属性和操作的对象的集合

继承:一个类为另一个类上的扩充的方式,子类继承父类,主要目的是代码复用 消息:对象间通信的手段

D是结构化程序设计或过程式(函数式)语言中的,一般的面向对象程序设计语言兼容这种方式,但不是其特征,故最佳选项为D

(6) 在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是______。 A. 可行性分析 B. 需求分析 C. 详细设计 D. 程序编码 (6) [答案]B

[考点]软件工程基础 [评析]

分析员对用户的要求作出分析,并画出数据流程图,该图通俗易懂,不涉及到如何在计算机上实现,这是需求分析阶段。 软件工程中的瀑布模型:

问题定义,可行性研究,需求分析,概要设计,详细设计,编码,测试,运行和维护 相关链点:

层次图和HIPO图是概要设计中的工具图;程序流程图、N-S图、问题分析PAD图、设计程序语言PDL是详细设计中的工具图

Page 3 of 51

(7) 在软件开发中,下面任务不属于设计阶段的是______。 A. 数据结构设计 B. 给出系统模块结构 C. 定义模块算法

D. 定义需求并建立系统模型 (7) [答案]D

[考点]软件工程基础 [评析]

A、B为概要设计中的,C为详细设计中的,D为分析阶段中的 (8) 数据库系统的核心是______。 A. 数据模型 B. 数据库管理系统 C. 软件工具 D. 数据库 (8) [答案]B

[考点]数据库设计基础 [评析]

数据库管理系统DBMS是数据库系统的核心,上层与用户打交道,底层与操作系统接口

注意点:数据库系统与数据库管理系统的区别

前者指的一整套业务系统,包括用户、应用程序、DBMS及操作系统的支持 (9) 下列叙述中正确的是______。

A. 数据库是一个独立的系统,不需要操作系统的支持 B. 数据库设计是指设计数据库管理系统

C. 数据库技术的根本目标是要解决数据共享的问题 D. 数据库系统中,数据的物理结构必须与逻辑结构一致 (9)

Page 4 of 51

[答案]C

[考点]数据库设计基础 [评析]

晕倒,数据库管理系统是人人都可设计的吗?那SYBASE和ORACLE等不都没饭吃了?普通人的数据库设计就是在DBMS的支持下设计几张表格,命几个名而已;D也错了的,数据库具有物理独立性和逻辑独立性,比如QQ是一个完整的数据库系统,我们使用的只是客户端应用程序,其数据库在腾讯的服务器上,物理独立性呢指的是数据库的底层结构改变了,而QQ的客户端不用变,对应地,逻辑独立性是指QQ的客户端改变了,数指据库的结构不用变了,否则,这么多QQ版本,那腾讯的服务器不是乱了套?

(10) 下列模式中,能够给出数据库物理存储结构与物理存取方法的是______。 A. 内模式 B. 外模式 C. 概念模式 D. 逻辑模式 (10) [答案]A

[考点]数据库设计基础 [评析]

通过前些题可知道,数据库的物理结构最底层,即对应内模式,对应的模式映像为内模式/模式(概念模式映像),逻辑独立性则对应于模式/外模式映像 (11) 算法的时间复杂度是指______。 A. 执行算法程序所需要的时间 B. 算法程序的长度

C. 算法执行过程中所需要的基本运算次数 D. 算法程序中的指令条数 (11) [答案]C

[考点]数据结构与算法

Page 5 of 51

[评析]

算法的复杂度分时间复杂度和空间复杂度。

时间复杂度:在运行算法时所耗费的时间为f(n)(即 n的函数)。 空间复杂度:实现算法所占用的空间为g(n)(也为n的函数)。 称O(f(n))和O(g(n))为该算法的复杂度。

简单的例子比如常见的顺序结构时间复杂度为O(1),1层循环里面次数为n,时间复杂度就是O(n),2层循环for i=1 to n,for j=1 to n算法时间复杂度为O(n2)(里面为n的平方),复杂度主要用于算法的效率比较与优化,比如排序,查找…

(12) 下列叙述中正确的是______。 A. 线性表是线性结构 B. 栈与队列是非线性结构 C. 线性链表是非线性结构 D. 二叉树是线性结构 (12) [答案]A

[考点]数据结构与算法 [评析]

一棵二叉树的一个结点下面可以有2个子结点,故不是线性结构(通俗地理解,看是否能排成条直线)。 此题与(2)题类似

(13) 设一棵完全二叉树共有699个结点,则在该二叉树中的叶子结点数为______。 A. 349 B. 350 C. 255 D. 351 (13) [答案]B

Page 6 of 51

[考点]数据结构与算法 [评析]

完全二叉树:若二叉树中最多只有最下面两层的结点的度可以小于2,并且最下面一层的结点(叶结点)都依次排列在该层最左边的位置上,这样的二叉树为完全二叉树。 比如图:

完全二叉树除叶结点层外的所有结点数(叶结点层以上所有结点数)为奇数,此题中,699是奇数,叶结点层以上的所有结点数为保证是奇数,则叶结点数必是偶数,这样我们可以立即选出答案为B!

如果完全二叉树的叶结点都排满了,则是满二叉树,易得满二叉树的叶结点数是其以上所有层结点数+1比如图:

此题的其实是一棵满二叉树,我们根据以上性质,699+1=700,700/2=350,即叶结点数为350,叶结点层以上所有结点数为350-1=349。 (14) 结构化程序设计主要强调的是______。 A. 程序的规模 B. 程序的易读性 C. 程序的执行效率 D. 程序的可移植性 (14) [答案]B

[考点]程序设计基础 [评析]

又是结构化的问题,何谓结构化? 简单地比如: VB: If...End If C: if..{...}

Pascle: Begin ...End

Page 7 of 51

我们在\结构\的中间写代码,从哪执行到哪结束我们能很快抓住! 此题中重要性为:B>C>D

(15) 在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段是______。 A. 概要设计 B. 详细设计 C. 可行性分析 D. 需求分析 (15) [答案]D

[考点]软件工程基础 [评析]

题中所述为需求分析

可行性研究包括经济可行性、技术可行性、操作可行性,即以最小的代价确定系统的规模是否现实

概要设计的任务是确定软件的总体结构、子结构和模块的划分

详细设计的任务是确定每一模块的实现细节,包括数据结构、算法和接口 也许有人这么久了还不知道什么叫系统,什么叫模块。

晕倒,这里罗嗦一下,软件工程中的系统指的整个软件系统,比如QQ的所有东西,我们用的是客户端程序,实际的东西放在腾讯公司的服务器上,主要是数据库,包括在中间的传输过程,这一整个相关的东东都叫做OICQ的系统;什么叫模块,这里不单指如VB里的\标准模块\、\类模块\,也不单指一个窗体或者一个文件,宏观上讲,软件工程中把一种功能或相关功能把它做成一个模块,这个模块有可能是一个过程,有可能是一个函数…从功能角度度量模块内的联系为模块的内聚(一般来说越强越好,不易出错);模块之间的联系为耦合,比如我们编程中常用把一实参的值赋给了函数中的形参,使函数完成某一功能,耦合度越低越好,独立性就强;

何谓独立性?比如我们二级编程都有考到全局变量、局部变量,函数中的局部变量独立性很强,函数外无法访问…

Page 8 of 51

何谓变量?晕~~~~~~~如果这都要说,那你可以不用考二级了。

(16) 数据流图用于抽象描述一个软件的逻辑模型,数据流图由一些特定的图符构成。下列图符名标识的图符不属于数据流图合法图符的是______。 A. 控制流 B. 加工 C. 数据存储 D. 源和潭 (16) [答案]A

[考点]软件工程基础 [评析]

数据流图用于需求分析阶段,在此阶段我们只考虑大致的数据流流向,而不关心内部具体的处理,以及如何在计算机上实现,不必讨论控制流,我们只关心的:数据流、数据储存、变换/加工(相当于一个黑盒,不关心内部细节)、外部实体,数据流图通俗易懂,因为它远离了计算机,用户(无需懂编程)和软件人员都易接受。

比如一个简单的软件系统逻辑模型:

输入流和输出流即D中的源和潭。

(17) 软件需求分析阶段的工作,可以分为四个方面:需求获取、需求分析、编写需求规格说明书以及______。 A. 阶段性报告 B. 需求评审 C. 总结 D. 都不正确 (17) [答案]B

[考点]软件工程基础 [评析]

Page 9 of 51

评审(复审)每阶段都有,把前三个方面说完了,还剩什么呢? 此题需要记一下,至于各名词的解释,顾名即可思义。 (18) 下述关于数据库系统的叙述中正确的是______。 A. 数据库系统减少了数据冗余 B. 数据库系统避免了一切冗余

C. 数据库系统中数据的一致性是指数据类型的一致 D. 数据库系统比文件系统能管理更多的数据 (18) [答案]A

[考点]数据库设计基础 [评析]

关于数据管理技术的三个阶段如下: 1.人工管理阶段 人工管理数据的特点是: (1)数据不保存。

(2)数据无专门软件进行管理。 (3)数据不共享。 (4)数据不具有独立性。 2.文件系统阶段

该阶段的数据管理具有如下特点: (1)数据可以长期保存。

(2)由文件系统管理数据。文件系统管理数据存在如下缺点: (1)数据共享性差,数据冗余度大。 (2)数据独立性差。 3.数据库系统阶段

与人工管理和文件系统阶段相比较,数据库系统阶段具有如下的特点: (1)数据结构化

(2)数据共享性高、冗余度小、易扩充 (3)数据独立性高

Page 10 of 51

(4)统一的数据管理和控制数据库管理系统必须提供以下几个方面的数据控制和保护功能:

(1)数据的安全性(security)保护。 (2)数据的完整性(integrity)控制。 (3)数据库恢复(recovery)。 (4)并发(concurrency)控制。 (5)事务(transaction)支持。

B错,为什么会有关系规范化理论,其主要目的之一是减少数据的冗余,说明数据库系统还存在一定的冗余;C错,数据完整性约束指一组完整性规则的集合,不一定是数据类型的一致性;D项也太菜鸟了吧,数据能管理存放多少数据主要看机子硬盘空间和一些相关的设置,比如在数据库管理系统中设置某个用户的空间最大为多少。

(19) 关系表中的每一横行称为一个______。 A. 元组 B. 字段 C. 属性 D. 码 (19) [答案]A

[考点]数据库设计基础 [评析]

字段:列,属性名

属性:实体的某一特性,如学生表中的学号、姓名…

码(主健):元组(实体)的惟一标识,比如学生有同名的,但学号是惟一的。 比如表:

学号 姓名 性别 院系

0221301 陈朝霞 女 油院矿机

0221310 周建峰 男 西南工业大学机电院 0221326 曾晓明 男 西南工业大学机电院

Page 11 of 51

0221315 郭文广 男 西南工业大学机电院 0123456 茂叶 男 油院机电&软件

(20) 数据库设计包括两个方面的设计内容,它们是______。 A. 概念设计和逻辑设计 B. 模式设计和内模式设计 C. 内模式设计和物理设计 D. 结构特性设计和行为特性设计 (20) [答案]A

[考点]数据库设计基础 [评析]

需求分析--(需求说明)-->概念设计--(概念结构)-->逻辑结构设计--(逻辑结构)-->物理设计--(物理结构)--> (21) 算法的空间复杂度是指______。 A. 算法程序的长度 B. 算法程序中的指令条数 C. 算法程序所占的存储空间

D. 算法执行过程中所需要的存储空间 (21) [答案]D

[考点]程序设计基础 [评析]

时间复杂度:在运行算法时所耗费的时间为f(n)(即 n的函数)。 空间复杂度:实现算法所占用的空间为g(n)(也为n的函数)。 算法为什么会占用存储存空间?

主要是内存空间,因为算法中的变量、地址等等通常保存在内存中(如果在虚存、缓存,甚至已在CPU中运行,也算占用了存储空间)。 (22) 下列关于栈的叙述中正确的是______。 A. 在栈中只能插入数据

Page 12 of 51

B. 在栈中只能删除数据 C. 栈是先进先出的线性表 D. 栈是先进后出的线性表 (22) [答案]D

[考点]数据结构与算法 [评析]

此题为基本概念,必记,注意:队列是先进先出的线性表,结合起来记不要搞混。 (23) 在深度为5的满二叉树中,叶子结点的个数为______。 A. 32 B. 31 C. 16 D. 15 (23) [答案]C

[考点]数据结构与算法 [评析]

首先搞清楚满二叉树与完全二叉树之间的区别,前面已解释过。 依次从上到下,可得出: 第1层结点数为1; 第2层结点数为2*1=2; 第3层结点数为2*2=4;

第n层结点数为2的n-1次幂,如图所示

(24) 对建立良好的程序设计风格,下面描述正确的是______。 A. 程序应简单、清晰、可读性好 B. 符号名的命名要符合语法 C. 充分考虑程序的执行效率 D. 程序的注释可有可无

Page 13 of 51

(24) [答案]A

[考点]程序设计基础 [评析]

结构化程序设计中力求程序的可读性(如代码清晰,结构明了,附加注释……),故D错;

如果程序写的都是错的,谈何风格?如果符号名的命名不符合语法,编译会报错,也是很基本的错误,B错;

追求程序的可读性要高于执行效率,C错。 (25) 下面对对象概念描述错误的是______。 A. 任何对象都必须有继承性 B. 对象是属性和方法的封装体 C. 对象间的通讯靠消息传递 D. 操作是对象的动态性属性 (25) [答案]A

[考点]程序设计基础 [评析]

此题为基本概念,必记!这里举几个例子说明以助大家理解: 比如 VB:

Command按纽类是个类,在窗体上画一个名为Command1的按纽即是创建该类的一个实例,也可创建另外一个实例如Command2,他们的属性可以调置为不同的,但是都是Command类的实例。Command1,Command2都是对象,它们封装了属性和方法,都是封装体,比如Name属性,Caption属性……宏观上可说Command1的Move操作是动态属性,对象间的通读靠消息传递,比如在Command1的单击事件中写上: Picture1.Print \消息传递\

Picture1是一个图片框对象,我们还可以调用Form_Load事件等等,都是通

Page 14 of 51

过消息传递的,即对象A向对象B发出消息,对象B执行怎样的操作。 C++: class Base { Public: Base(){} ~Base(){} ... };

class Derive:Public Base { Public: ... Print() {

Cout<<\打印函数!\} };

void main() {

Derive a; Base *p; ... }

Base为基类,Derive为基类上的派生类,它继承了基类的一些属性和方法等,a为创建的实例,即是一个对象,它封装了类Derive的所有性性和方法,特别是私有的属性和方法,直接调用它们会失败,这就是类的封装性。对象间的通讯是靠消息传递的,比如我们在内存中删除p所指的一个对象,用delete p语句,会调用类Base的析构函数~Base();我们也可用a.Print()语句来调用Derive

Page 15 of 51

类的Print()函数,对象a具有类Derive的属性和方法(在C++中一般用函数来实现,比如Print(),我们可以说这操作是对象a的动态属性) (26) 下面不属于软件工程的3个要素的是______。 A. 工具 B. 过程 C. 方法 D. 环境 (26) [答案]D

[考点]软件工程基础 [评析]

这里阐述一下,以上答案为原稿的答案,有的书上答案应该为B,解释如下: 软件工程包括的三要素是:软件开发方法学、工具和环境支持,而其主体内容是软件开发方法学。

1、软件开发方法,比如根据瀑布模型有结构化分析与设计方法,有原型化开发方法

2、软件开发工具各个瀑存模型阶段都有相关工具,比如需求分析阶段有DFD数据流程图,详细设计阶段有HIPO图或PAD图,编码工具有VC、VB…… 3、软件开发环境是全面支持软件开发全过程的软件工具集合。

如果你有权威且详尽的解释,还请邮给茂叶: dj8529@sina.com 或去我主页上留言

此题的争论,意义性不大,燃眉之急是应负考试。 :) 软件工程三要素工具、方法、过程,请大家记一下。 (27) 程序流程图(PFD)中的箭头代表的是______。 A. 数据流 B. 控制流 C. 调用关系 D. 组成关系 (27)

Page 16 of 51

[答案]B

[考点]软件工程基础 [评析]

如果A,那么B,否则C,这是我们二级中很熟悉的程序流程方式,我们可以画成相应的PFD图或N-S图。易知箭头控制应该是哪条语句执行,即B答案。 (28) 在数据管理技术的发展过程中,经历了人工管理阶段、文件系统阶段和数据库系统阶段。其中数据独立性最高的阶段是______。 A. 数据库系统 B. 文件系统 C. 人工管理 D. 数据项管理 (28) [答案]A

[考点]数据库设计基础 [评析]

关于数据管理技术的三个阶段如下表: 1.人工管理阶段 人工管理数据的特点是: (1)数据不保存。

(2)数据无专门软件进行管理。 (3)数据不共享。 (4)数据不具有独立性。 2.文件系统阶段

该阶段的数据管理具有如下特点: (1)数据可以长期保存。

(2)由文件系统管理数据。文件系统管理数据存在如下缺点: (1)数据共享性差,数据冗余度大。 (2)数据独立性差。 3.数据库系统阶段

Page 17 of 51

与人工管理和文件系统阶段相比较,数据库系统阶段具有如下的特点: (1)数据结构化

(2)数据共享性高、冗余度小、易扩充 (3)数据独立性高

(4)统一的数据管理和控制数据库管理系统必须提供以下几个方面的数据控制和保护功能:

(1)数据的安全性(security)保护。 (2)数据的完整性(integrity)控制。 (3)数据库恢复(recovery)。 (4)并发(concurrency)控制。 (5)事务(transaction)支持。

(29) 用树形结构来表示实体之间联系的模型称为______。 A. 关系模型 B. 层次模型 C. 网状模型 D. 数据模型 (29) [答案]B

[考点]数据库设计基础 [评析]

层次模型结构是一棵有向树,树中的每个结点代表一种记录类型,这些结点满足:有且仅有一个结点无双亲(根结点),其它结点有且仅有一个双亲结点。 网状模型则相当于一个有向图,与层次模型结构不同的是:一个结点可以有多个双亲结点,且多个结点可以无双亲结点。

关系模型则是二维表,一张表即为一个关系,这个很常见,如学生关系(学号,姓名,出生年月,性别),就像我们的办公软件中电子表格那样的表格。 D项的数据模型不是数据库的基本模型。

(30) 关系数据库管理系统能实现的专门关系运算包括______。

Page 18 of 51

A. 排序、索引、统计 B. 选择、投影、连接 C. 关联、更新、排序 D. 显示、打印、制表 (30) [答案]B

[考点]数据库设计基础 [评析]

此题为数据库的基本概念,如果你完全没学过数据库,可以对照办工软件的电子表格进行如下理解:

选择:我们根据某条件选择出一行或多行元组(一个元组即为二维表中的一行) 投影:按字段(也称属性,比如学生关系(学号,姓名,出生年月,性别),学号、姓名……都是属性)选取一列或多列(一个二维表中所有元组在某一列或几列上截取出来)。

连接:2个或2个以上的表连接组成一张新的表,通常有条件连接。比如学生关系(学号,姓名,系号),又有一张系表(系号,系名,主任),2张表可以合并为一张这样的表(学号,姓名,系号,系名,主任) (31) 算法一般都可以用哪几种控制结构组合而成______。 A. 循环、分支、递归 B. 顺序、循环、嵌套 C. 循环、递归、选择 D. 顺序、选择、循环 (31) [答案]D

[考点]数据结构与算法 [评析]

结构化程序设计中,基本的控制结构为顺序、选择、循环。各种具体的程序设计语言中的一些控制结构都可以划分到这些类中。比如VB里的Select Case语句、If...Elseif...Else...End If,C/C++中的switch()、if{}……都属于选择控

Page 19 of 51

制结构。相应的for循环和while语句都属于循环结构。按从上到下顺序执行的即是顺序控制结构。

(32) 数据的存储结构是指______。 A. 数据所占的存储空间量

B. 数据的逻辑结构在计算机中的表示 C. 数据在计算机中的顺序存储方式 D. 存储在外存中的数据 (32) [答案]B

[考点]数据结构与算法 [评析]

这是个基本概念题。存储空间量只是数据的存储结构的一个属性,答案C也太片面,比如链表也是种存储方式,而非线性的还有树、图……我们所学的数据结构不涉及到数据在计算机外存(比如硬盘、软盘)具体的方式,而仅关心它们在内存中逻辑结构,比如数组,它是内存中一片连续的数据存储,我们对每一个元素都可以顺序地访问,只需要知道某一个元素的地址,其它数据元素的地址可以据库下标与数组类型(如字符型、整型……)所占的存储空间就可算出每个元素的地址,故顺序访问所有元素。但是对于具体数据在内存中的物理存储,我们很少关心。比如某个数组建立时,它的首地址具体是多少?它们在内存中的二进制表示是什么的?

另,什么叫物理结构,什么叫逻辑结构,可以这样来理解,就好比物理结构是一个人的肉体,逻辑结构是一个人的灵魂,类似于计算机中硬件与软件的说法。就好比我们上QQ,发送消息、接收消息,基本上近似大众人的思维,但发送消息与接收消息这些的具体技术过程或它们在CPU和硬盘上的活动,甚至二进制是什么呢?去问腾讯公司 (33) 设有下列二叉树:

对此二叉树中序遍历的结果为______。 A. ABCDEF B. DBEAFC C. ABDECF

Page 20 of 51

D. DEBFCA (33) [答案]B

[考点]数据结构与算法 [评析]

该题原稿没图,故无从解释,此知识点的详解部分请看53题

(34) 在面向对象方法中,一个对象请求另一对象为其服务的方式是通过发送______。 A. 调用语句 B. 命令 C. 口令 D. 消息 (34) [答案]D

[考点]程序设计基础 [评析]

通过消息机制。太理论方面的不多说,现举例说明。 C++:

比如在VC++中,单击了一个菜单命令项\退出\,我们要实现退出程序,如何来实现?很简单,只要向窗体发送一个PostQuitMessage(0);就可以关闭窗体。

这个在VB中还简单,三个字符\即可解决,相当于向所有窗体发送一个销毁窗体的消息,即\窗体名\语句。(如果是单个窗体的话,即相当于Unload Me语句) VB:

Public a As Integer

Private Sub Command1_Click() a = 20 Print a End Sub

Page 21 of 51

Private Sub Command2_Click()

Form_Load ''''''''''''''这里调用Form_Load()过程,实用a=10 Print a End Sub

Private Sub Form_Load() a = 10 End Sub

命令按纽Command2向其母窗体发送一个消息,使其为Command2服务。 Command2是CommandButton类的一个对象,主窗体是窗体类的一个对象。 关于类与对象的理解,请大家看前面的题的详解。

(35) 检查软件产品是否符合需求定义的过程称为______。 A. 确认测试 B. 集成测试 C. 验证测试 D. 验收测试 (35) [答案]A

[考点]软件工程基础 [评析]

A、C、D相近,但A为比较正规的说法名词。

确认测试也称合格测试或验收测试,主要由用户参加,检验软件规格说明的技术标准的符合程度,是保证软件质量的最后关键环节。

单元测试主要采用白盒法,之后再采用集成测试,主要采用黑盒法。这些主要由开发者的工作,而无用户参与,不是检查是否符合需求定义的。 什么叫白盒黑盒? 相当于这样理解吧:

白盒测试,我们要注意到代码;黑盒,我们只关心程序运行的输入输出是否正确,一般是大量的测试,主要于非增量测试中使用,而非增量测试又一般适用于规模

Page 22 of 51

较小的系统开发。可以想象,一个很大很复杂的系统,我们用黑盒法来集成测试,效果可想而知。

(36) 下列工具中属于需求分析常用工具的是______。 A. PAD B. PFD C. N-S D. DFD (36) [答案]D

[考点]软件工程基础 [评析]

PAD,问题分析图,常用于详细设计;

PFD,程序流程图,常用于详细设计,我们很多如C、VB…程序设计书上都有简单的实例;

N-S,方框图,比程序流程图更灵活,也常用于详细设计;

DFD,数据流图,远离具体在计算机上的实现,不懂计算机的用户也能看懂,用于需求分析。

什么叫详细设计?它与我们编程有什么区别?

这样理解吧,公司的高级程序员,就是软件设计师,他们会搞详细设计的(在概要设计之后),比如用PAD或N-S画个图,它不涉及具体的某种程序设计语言的实现,但程序员们都能看懂,程序员再用某种语言(比如C、VB、JAVA…)按照图来写代码。这个过程,高级程序员完成设计工作,程序员完成写代码工作。 (37) 下面不属于软件设计原则的是______。 A. 抽象 B. 模块化 C. 自底向上 D. 信息隐蔽 (37) [答案]C

Page 23 of 51

[考点]软件工程基础 [评析]

我们无论是设计与编写代码,无论是画数据流图还是程序流图,习愦性思维都是先有输入才有输出,从下至下。自底向上不是软件设计的原则。 (38) 索引属于______。 A. 模式 B. 内模式 C. 外模式 D. 概念模式 (38) [答案]B

[考点]数据库设计基础 [评析]

要特别记住此题的答案。

索引的写入修改了数据库的物理结构,而不是简单的逻辑设计。内模式规定了数据在存储介质上的物理组织方式、记录录址方式。

(39) 在关系数据库中,用来表示实体之间联系的是______。 A. 树结构 B. 网结构 C. 线性表 D. 二维表 (39) [答案]D

[考点]数据库设计基础 [评析]

关系数据库中的关系,用二维表表示,A为层次数据模型的,B为网状数据模型的。

数据库模型分为:

层次模型、网状模型、关系模型、面向对象模型。

Page 24 of 51

(40) 将E-R图转换到关系模式时,实体与联系都可以表示成______。 A. 属性 B. 关系 C. 键 D. 域 (40) [答案]B

[考点]数据库设计基础 [评析]

基本概念题,实体与联系可以表示成关系,关系可以表示成二维表。 (41) 在下列选项中,哪个不是一个算法一般应该具有的基本特征______。 A. 确定性 B. 可行性 C. 无穷性

D. 拥有足够的情报 (41) [答案]C

[考点]程序设计基础 [评析]

算法具有确定性、可行性,并拥有足够的情报。 (42) 希尔排序法属于哪一种类型的排序法______。 A. 交换类排序法 B. 插入类排序法 C. 选择类排序法 D. 建堆排序法 (42) [答案]B

[考点]数据结构与算法 [评析]

Shell排序法 输入:数组名称(也就是数组首地址)、数组中元素个数

Page 25 of 51

思想为:在直接插入排序算法中,每次插入一个数,使有序序列只增加1个节点,

并且对插入下一个数没有提供任何帮助。如果比较相隔较远距离(称为 增量)的数,使得数移动时能跨过多个元素,则进行一次比较就可能消除 多个元素交换。D.L.shell于1959年在以他名字命名的排序算法中实现 了这一思想。算法先将要排序的一组数按某个增量d分成若干组,每组中 记录的下标相差d.对每组中全部元素进行排序,然后再用一个较小的增量 对它进行,在每组中再进行排序。当增量减到1时,整个要排序的数被分成 一组,排序完成。

下面的函数是一个希尔排序算法的一个实现,初次取序列的一半为增量, 以后每次减半,直到增量为1。以C语言为例。 void shell_sort(int *x, int n) {

int h, j, k, t;

for (h=n/2; h>0; h=h/2) /*控制增量*/ {

for (j=h; j

t = *(x+j);

for (k=j-h; (k>=0 && t<*(x+k)); k-=h) {

*(x+k+h) = *(x+k); }

*(x+k+h) = t; } } }

故属于插入类排序法。

(43) 下列关于队列的叙述中正确的是______。

Page 26 of 51

A. 在队列中只能插入数据 B. 在队列中只能删除数据 C. 队列是先进先出的线性表 D. 队列是先进后出的线性表 (43) [答案]C

[考点]数据构与算法 [评析]

队列是先进先出的,栈是先进后出的,2者的区别一定要搞清楚。

(44) 对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为______。 A. N+1 B. N C. (N+1)/2 D. N/2 (44) [答案]B

[考点]数据结构与算法 [评析]

很简单,我们的二级程序设计语言书中都有此算法,另外还要掌握二分法查找,这也是我们二级中常考的。

那么二分法最坏的情况为多少次呢? >log2 n的最小整数值。

比如n为4,最坏的情况要比较3次; n为18,最坏的情况要比较5次。

二分法适用于已排序的顺序表(我们二级语言中都是数组),考二级书里的,这里不再罗嗦。

(45) 信息隐蔽的概念与下述哪一种概念直接相关______。 A. 软件结构定义

Page 27 of 51

B. 模块独立性 C. 模块类型划分 D. 模拟耦合度 (45) [答案]B

[考点]软件工程基础 [评析]

模块独立性越强,则信息隐蔽性越好。 举个例, VB:

在多重窗体设计时,每个窗体里的变量尽量与其它窗体里变量无关,比如少用Public声明的变量,即全局变量,当多个窗体共享全局变量越多时,窗体的独立性就越差。 C:

头文件里的一些函数,一般不用到全局变量,否则在主程序里出乱子的情况很多,我们在模块化开发时,尽量使每个模块独立,强功能内聚,分工明确,调试程序也要方便得多。 C++:

考此项的朋友估计不用我多讲,类的封装性就是一个很好的说明。

(46) 面向对象的设计方法与传统的的面向过程的方法有本质不同,它的基本原理是______。

A. 模拟现实世界中不同事物之间的联系 B. 强调模拟现实世界中的算法而不强调概念

C. 使用现实世界的概念抽象地思考问题从而自然地解决问题 D. 鼓励开发者在软件开发的绝大部分中都用实际领域的概念去思考 (46) [答案]C

[考点]软件工程基础

Page 28 of 51

[评析] 我们举个例,

从各种语言的结构体类型出发,我们知道,结构体中可以定义很多变量,对每个变量执行相同的操作,挨个挨个写出,很麻烦。假设该结构体有如下变量: 草鱼、田鱼、鲫鱼……

它们都在一口池塘里,现在执行:它们都上来 传统的程序设计是: 草鱼上来 田鱼上来 鲫鱼上来 ……

一条一条都写出,是不是很麻烦? 改进一下,我们用个循环:

n等于从1到10(假设共有10种鱼) 第n种鱼上来

还是很麻烦,现实中我们很易想到用\面向对象的思想\,池塘里所有的鱼都是一个结构体变量,名为鱼,执行: 鱼上来

意思即所有的鱼都上来。

现特定于面象对象语言中的类,鱼,就可以看作为一类。 这就属于 C 项:

使用现实世界的概念抽象地思考问题从而自然地解决问题

这样罗嗦的解释望大家别晕,旨在帮助部分人的确难想通的,为应试,你能背下答案也行。

(47) 在结构化方法中,软件功能分解属于下列软件开发中的阶段是______。 A. 详细设计 B. 需求分析 C. 总体设计

Page 29 of 51

D. 编程调试 (47) [答案]C

[考点]软件工程基础 [评析]

从先到后一排,是:

需求分析、总体设计、详细设计、编程调试

需求分析远离在计算机上的实现,谈不上功能的分解;

有了需求分析的报告,软件设计员可以思考我要让软件怎么做,开始总体设计,其间将软件的功能分解,确定模块之间的接口;

有了每个模块功能的分解,再对每个模块进入详细设计阶段; 接下来再是程序员的任务,编写代码,开始编程调试。 (48) 软件调试的目的是______。 A. 发现错误 B. 改正错误 C. 改善软件的性能 D. 挖掘软件的潜能 (48) [答案]B

[考点]软件工程基础 [评析] 倒!

一个程序调试是为了干什么? 还不是为了改正错误?

发现错误?这只是一个过程,改正错误之前必须先发现错误,总不能目的就仅为发现错误吧。

(49) 按条件f对关系R进行选择,其关系代数表达式为______。 A. R|X|R B. R|X|R f

Page 30 of 51

C. бf(R) D. ∏f(R) (49) [答案]C

[考点]数据库设计基础 [评析]

C是选择一行,D是投影一列,二者要区分开。

如果不仅谈此题的话,有关关系代数,内容有些多,这里不是一两句能说清,可以看看相关《数据库》的资料中的关系代数,里面写得很详细。为应试,情急之下能记住几个题答案就行。

(50) 数据库概念设计的过程中,视图设计一般有三种设计次序,以下各项中不对的是______。 A. 自顶向下 B. 由底向上 C. 由内向外 D. 由整体到局部 (50) [答案]D

[考点]数据库设计基础 [评析]

通常有如下几种方法:

1、自顶向下。先全局框架,然后逐步细化 2、自底向上。先局部概念结构,再集成为全局结构 3、由里向外。先核心结构,再向外扩张

4、混合策略。1与2相结合,先自顶向下设计一个概念结构的框架,再自底向上为框架设计局部概念结构

(51) 在计算机中,算法是指______。 A. 查询方法 B. 加工方法

Page 31 of 51

C. 解题方案的准确而完整的描述 D. 排序方法 (51) [答案]C

[考点]数据结构与算法 [评析]

A、B、D都过于片面,此题直接选答案也很简单。 (52) 栈和队列的共同点是______。 A. 都是先进后出 B. 都是先进先出

C. 只允许在端点处插入和删除元素 D. 没有共同点 (52) [答案]C

[考点]数据结构与算法 [评析]

栈是先进后出的,队列是先进先出的,共同点是只允许在端点处插入和删除元素。栈都是在一端进与出,而队列是在一端进在另一端出。

(53) 已知二叉树后序遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是______。 A. cedba B. acbed C. decab D. deabc (53) [答案]A

[考点]数据结构与算法 [评析]

后序又叫后根,一次递归过程是先左再右最后根;中序是先左再根最后右。

Page 32 of 51

比如下图:

前序是:abc 中序是:bac 后序是:bca

题中据后序遍历序列,一眼得知c结点是根,那么据中序deba结点都在一边,或都在根结点左边,或右边;据中序遍历序列得知全在根结点的左边。 接下来据后序得出e结点是紧挨着c结点的左子女,再据中序得知d是e的左子女,ba是右子树。

再据后序得b是e的右子女,再据中序得a是b的右子女。 分析结果得二叉树图示如下:

因为我茂叶数据结构是自学的,分析此类型的题我都是用自己的方法(递归分析的方法),要边分析边画图,一步一步连结起来,最后再根据题中的遍历检查图是否画对,如果都符合题目,最后再可根据图来得所求的遍历。

再次声明,此所有二级公基题全是我一人的思路写的,如果你觉得不可靠,可以看其它的书。

(54) 在下列几种排序方法中,要求内存量最大的是______。 A. 插入排序 B. 选择排序 C. 快速排序 D. 归并排序 (54) [答案]D

[考点]数据结构与算法 [分析]

我们对比一个排序方法的优越性有\平均时间\、\最坏情况时间\和\辅助空间\。其中辅助空间一般是排序中需要额外的内存开销,这些内存开销一般据一些如中

Page 33 of 51

间变量(暂存变量)、比较与交换等等来决定。

插入排序和选择排序的辅助空间都是o(1),快速排序是o(nlog2n),归并排序是o(n)。

可知归并排序要求内存量最大,我们也可以从其变量及循环个数也以看出归并排序要求内存量最大。

(55) 在设计程序时,应采纳的原则之一是______。 A. 程序结构应有助于读者理解 B. 不限制goto语句的使用 C. 减少或取消注解行 D. 程序越短越好 (55) [答案]A

[考点]程序设计基础 [评析]

前面的题中已解释过,二级的各种程序设计语言教程都会对结构化程序设有一定的介绍,比如goto语句的限制使用,基本上每本书上都会提到。

其中A,即易读性比程序的效率更显得重要,这是结构化程序设计原则提倡的,也是我们进行开发时非常重要的一点。 (56) 下列不属于软件调试技术的是______。 A. 强行排错法 B. 集成测试法 C. 回溯法 D. 原因排除法 (56) [答案]B

[考点]软件工程基础 [评析]

耍个小聪明:)

我们严格区分调试与测试,调试是已知有错误而来找错误,是被动的;测试有很

Page 34 of 51

多种,比如未发现错误但不能保证程序没错而来找BUG,还比如我们运行测试程序是否符合用户的要求,是主动的。不用说答案就是B了 :) A、C、D都是具体的程序调试方法,而B是宏观的程序测试方法。

测试有单元测试、集成测试、确认测试、系统测试。比如我们在进行单元测试时,发现程序有错误,我们再可以根据A、C、D的方法来找错误。 题外话:

很多人学软件工程时认为软件工程太无聊了,似乎全部都是些背背记记的东西,但对于一个软件构架师,软件工程是非常重要的,这就不能是些背背的东西了,最重要的是理解,要彻底地理解,还得有些开发经验才行。《软件工程》这学科是从实践中得出来的,同样也需要赋予给实践中去,这样才有用! (57) 下列叙述中,不属于软件需求规格说明书的作用的是______。 A. 便于用户、开发人员进行理解和交流

B. 反映出用户问题的结构,可以作为软件开发工作的基础和依据 C. 作为确认测试和验收的依据 D. 便于开发人员进行需求分析 (57) [答案]D

[考点]软件工程基础 [评析]

A、B、C都是作用,D说法有一定的错误,开发人员包括很多,比如程序员的工作就不是进行需求分析。

(58) 在数据流图(DFD)中,带有名字的箭头表示______。 A. 控制程序的执行顺序 B. 模块之间的调用关系 C. 数据的流向 D. 程序的组成成分 (58) [答案]C

[考点]软件工程基础

Page 35 of 51

[评析]

顾名思义,数据流图就是带有方框(外部实体)、圆圈(变换/加工)和带有名字的箭头以表示数据的流向。需求分析中常用的分析图,它远离计算机上的具体实现,软件人员和用户都能看懂,有益于和用户交流。 (59) SQL语言又称为______。 A. 结构化定义语言 B. 结构化控制语言 C. 结构化查询语言 D. 结构化操纵语言 (59) [答案]C

[考点]数据库设计基础 [评析]

学VF和ACCESS的朋友轻而易举选出答案,考其它的朋友们若没学数据库技术这一章节,则要记一下了。 Structured Query Language 结构化 查询 语言(语句)

(60) 视图设计一般有3种设计次序,下列不属于视图设计的是______。 A. 自顶向下 B. 由外向内 C. 由内向外 D. 自底向上 (60) [答案]B

[考点]数据库设计基础 [评析]

通常有如下几种方法:

1、自顶向下。先全局框架,然后逐步细化 2、自底向上。先局部概念结构,再集成为全局结构

Page 36 of 51

3、由里向外。先核心结构,再向外扩张

4、混合策略。1与2相结合,先自顶向下设计一个概念结构的框架,再自底向上为框架设计局部概念结构

(61) 数据结构中,与所使用的计算机无关的是数据的______。 A. 存储结构 B. 物理结构 C. 逻辑结构 D. 物理和存储结构 (61) [答案]C

[考点]数据结构与算法 [评析]

通过前面的一些题的解释,相信此题对大家也很简单了。

逻辑结构更接近人的思想,比如栈的先进后出的结构,这是逻辑结构,如果研究到了栈在内存中的结构,如地址、地址里的内容等等,这就是物理结构了,我们一般无须过于深入底层地钻研。

(62) 栈底至栈顶依次存放元素A、B、C、D,在第五个元素E入栈前,栈中元素可以出栈,则出栈序列可能是______。 A. ABCED B. DBCEA C. CDABE D. DCBEA (62) [答案]D

[考点]数据结构与算法 [评析]

栈是先进后出的,因为在E放入前,A、B、C、D已经依次放进栈里了,故这四个元素出栈的顺序只能是D、C、B、A,E可是其中排序的任何位置,答案只有D符合了。

Page 37 of 51

(63) 线性表的顺序存储结构和线性表的链式存储结构分别是______。 A. 顺序存取的存储结构、顺序存取的存储结构 B. 随机存取的存储结构、顺序存取的存储结构 C. 随机存取的存储结构、随机存取的存储结构 D. 任意存取的存储结构、任意存取的存储结构 (63) [答案]B

[考点]数据结构与算法 [评析]

顺序存储结构可以以数组为例子,它在内存中的一片连续的储存空间,从第一个元素到最后一个元素,只要根据下标就可以访问。二级的各种程序设计语言都有。 链式存储结构可以以C/C++语言中的链表为例,各个链结点无须存放在一片连续的内存空间,而只需要指针变量指过来指过去,实现随机存取。 (64) 在单链表中,增加头结点的目的是______。 A. 方便运算的实现 B. 使单链表至少有一个结点 C. 标识表结点中首结点的位置

D. 说明单链表是线性表的链式存储实现 (64) [答案]A

[考点]数据结构与算法 [评析]

举个例子,假如我们写一个实现链表删除一个元素的函数(或过程),供共享用,函数的参数有2个,一个指针变量(指向链表的头结点),一个字符变量(待删除的元素)。通过链表头结点的指针传给函数的第一个指针变量参数,就可方便实现是哪一个链表的操作。

如果你考的科目没有指针,此题答案记一下就行了。

(65) 软件设计包括软件的结构、数据接口和过程设计,其中软件的过程设计是指______。

Page 38 of 51

A. 模块间的关系

B. 系统结构部件转换成软件的过程描述 C. 软件层次结构 D. 软件开发过程 (65) [答案]B

[考点]软件工程基础 [评析]

相当于详细设计,比如N-S图就是一种,它不用具体的某种语言实现,但描述了程序的思路,有了这就可以很轻松转换为某种语言的程序源代码。这是一种系统结构部件转换成软件的过程描述。

(66) 为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种图称为______。 A. PAD图 B. N-S图 C. 结构图 D. 数据流图 (66) [答案]B

[考点]软件工程基础 [评析]

二级科目的很多教程都在前N-S图的例子,比如C语言教程基本上都有,程序流程图大部分科目也有例子。这里再举个例子。 比如:

如果2等于3,则变量a=1,否则a=0。 我们用N-S图表示:

转换成VB: If 2=3 Then

Page 39 of 51

a=1 else a=0 End If

转换成C/C++/JAVA: if(2==3) a=1; else a=0;

(67) 数据处理的最小单位是______。 A. 数据 B. 数据元素 C. 数据项 D. 数据结构 (67) [答案]C

[考点]数据结构与算法 [评析]

此题比较弱智,本来无从解释。

\数据\过于宏观,比如数据库里的所有内容都可叫数据,它是不是数据处理的最小单位呢?

\数据元素\中的\元素\,如果要死钻牛角尖,的确没\数据项\说得更合适。 \数据结构\,这个范围又过于大了。

(68) 下列有关数据库的描述,正确的是______。 A. 数据库是一个DBF文件 B. 数据库是一个关系

C. 数据库是一个结构化的数据集合 D. 数据库是一组文件 (68)

Page 40 of 51

本文来源:https://www.bwwdw.com/article/njvg.html

Top