ImageVerifierCode 换一换
格式:DOCX , 页数:22 ,大小:33.41KB ,
资源ID:20813453      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/20813453.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(全国计算机等级考试二级公共基础知识文档格式.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

全国计算机等级考试二级公共基础知识文档格式.docx

1、针对实际问题而设计的算法,执行后能够得到满意的结果。2、确定性(Definiteness):算法中的每一个步骤都必须有明确的定义,不允许出现歧义性。3、有穷性(Finiteness):算法必须在有限时间内做完,即必须在执行有限个步骤之后终止。v 时间复杂度:该算法执行的时间耗费,它是该算法所求解问题规模n的函数。v 空间复杂度:该算法执行时所耗费的存储空间,它也是问题规模n的函数。二、线性表:v 线性表(Linear List):是由n(n=0)个数据元素(结点)a1,a2,a3,an组成的有限序列。对于非空的线性表,有且仅有一个开始结点a1,它没有直接前趋;有且仅有一个终端结点an,它没有直

2、接后继;其余的结点有且仅有一个直接前趋结点和一个直接后继结点。v 线性表的存储结构:1、顺序存储(Sequential List):将线性表的结点按逻辑次序依次存放在一组地址连续的存储单元里,用这种方法存储的线性表称为顺序表。2、链式存储(Linked List):逻辑上相邻的结点,物理上也相邻,存储单元可以是连续的,也可以是不连续的,在存储每个结点值的同时,还存储指向其后继结点的地址,用这种方法存储的线性表称为链表。v 常见的运算有:表的初始化、求表的长度、取表中的第i个结点、查找结点、插入新的结点、删除结点。v 顺序表和链表的比较:1、基于空间的考虑:A、顺序表的存储空间是静态分配的,而链

3、表的存储空间是动态分配的。B、顺序表占的存储空间必须是连续的,而链表占的存储空间可以是连续的,也可是不连续的C、顺序表存储密度为1,而链表中的每个结点,除了数据域外,还要额外的设置指针域,存储密度小于12、基于时间的考虑:A、在链表中的任何位置上进行插入和删除,只需要修改指针,而顺序表中平均将要移动近一半的结点。B、顺序表是随机存取结构,它的存取时间为O(1),而链表需从头结点顺着链扫描链表。 总之,当线性表的长度变化不大,易于事先确定其大小时,为了节约存储空间,宜采用顺序表作为存储结构;当线性表的长度变化较大,难以估计其存储规模时,以采用链表作为存储结构为好。若线性表的操作主要是进行查找,很

4、少做插入和删除操作时,采用顺序表做存储结构为宜;对于频繁进行插入和删除的线性表,宜采用链表做存储结构。关于线性表的描述中,错误的是( ) A、线性表是线性结构 B、线性表的顺序存储结构,必须占用一片连续的存储单元C、线性表是单链表 D、线性表的链式存储结构,不必占用一片连续的存储单元用数组表示线性表的优点是( )A、便于插入和删除操作 B、便于随机存取C、可以动态地分配存储空间 D、不需要占用一片连续的存储空间三、栈:v 栈(Stack):是限制仅在表的一端进行插入和删除运算的线性表,通常称插入、删除的这一端为栈顶(Top),另一端称为栈底(Bottom)。当表中没有元素时称为空栈。是一种后进

5、先出的线性表,又称为LIFO表。v 栈的基本运算有:栈的初始化、判栈空、判栈满、进栈、出栈等v 栈的存储:顺序存储、链式存储若进栈的输入序列是A、B、C、D、E,并且在它们进栈的过程中可以进行出栈操作,则不可能出现的出栈序列是( )A、EDCBA B、DECBA C、DCEAB D、ABCDE四、队列:v 队列(Queue):也是一种运算受限的线性表,它只允许在表的一端进行插入,而在另一端进行删除。允许删除的一段称为队头(Front),允许插入的一段称为队尾(Rear)。(类似于生活中的购物排队)。是一种先进先出的线性表,又称为FIFO表。v 队列的基本运算:队列的初始化、判队空、判队满、入队

6、、出队v 队列的存储实现:一个队列的入队序列是1,2,3,4,则队列的输出序列是 ( )A、4,3,2,1 B、1,2,3,4 C、1,4,3,2 D、3,2,4,1五、串:v 串(String):是零个或多个字符组成的有限序列。串中所包含的字符个数称为该串的长度。串中任意个连续字符组成的子序列称为该串的子串,包含子串的串相应地称为主串注:空串是任意串的子串,任意串是其自身的子串v 串有串常量、串变量之分:1、串常量在程序中只能被引用但不能改变其值,即只能读不能写。2、串变量其值是可以改变的。v 串的基本运算:求串长、串复制、串联接、串比较、字符定位、六、树(非线性结构):v 树(Tree):

7、是n(n=0)个结点的有限集T,T(n=0)为空时称为空树,否则它满足如下两个条件:1、有且仅有一个特定的称为根(Root)的结点2、其余的结点可分为m(m=0)个互不相交的子集T1,T2,.,Tm,其中每个子集本身又是一棵树,并称其为根的子树(Subtree)。v 在树的树形图表示中,结点通常是用圆圈表示的,结点的名字一般是写在圆圈旁边,有时亦可写在圆圈内。v 度(Degree):一个结点拥有的子树数称为该结点的度。一棵树的度是指该树中结点的最大度数。v 叶子(Leaf):度为零的结点称为叶子或终端结点v 分支结点(Node):度不为零的结点称为分支结点。v 树中某个结点的子树之根称为该结点

8、的孩子(Child)结点或子结点,相应的该结点称为孩子结点的双亲(Parents)结点或父结点。v 同一个双亲的孩子称为兄弟结点(Sibling)v 结点的层数(Level)是从根起算,设根的层数为1,其余结点的层数等于其双亲结点的层数加1.v 树中结点的最大层数称为树的高度(Height)或深度(Depth).v 森林(Forest):是m(m=0)棵互不相交的树的集合。删去一棵树的根,就得到一个森林,反之,加上一个结点作树根,森林就变为一棵树。v 二叉树(Binary Tree):=0)个结点的有限集,它或者是空集(n=0),或者由一个根结点及两棵互不相交的、分别称作这个根的左子树和右子树

9、的二叉树组成。二叉树中,每个结点最多只能有两棵子树,并且有左右之分。v 二叉树的五种基本形态:具有3个结点的二叉树有几种形态。v 满二叉树(Full Binary Tree):一棵深度为k且有2k-1个结点的二叉树称为满二叉树v 完全二叉树(Complete Binary Tree):若一棵二叉树至多只有最下面的两层上结点的度数可以小于2,并且最下一层上的结点都集中在该层最左边的若干位置上,则此二叉树称为完全二叉树。二叉树的性质:性质1:二叉树第i层上的结点数目最多为2i-1(i=1)性质2:深度为k的二叉树至多有2k-1个结点(k性质3:在任意一棵二叉树中,若终端结点的个数为n0,度为2的结

10、点数为n2,则n0=n2+1性质4:具有n个结点的完全二叉树的深度为lgn+1(取下整) 或 lg(n+1)(取上整)。一棵二叉树的结点数为18个,求它的最小高度已知度为2的结点数为15个,求叶子结点数二叉树的遍历:v 遍历(Traversal):是指沿着某条搜索路线,依次对树中每个结点均做一次且仅做一次访问。前序遍历:(又称为先序遍历、先根遍历)若二叉树为空,则执行空操作。否则:1、访问根结点;2、前序遍历左子树;3、前序遍历右子树。中序遍历:(又称为中根遍历)1、中序遍历左子树;2、访问根结点;3、中序遍历右子树。后序遍历:(又称为后根遍历)1、后序遍历左子树;2、后序遍历右子树;3、访问

11、根结点。已知一棵二叉树的中序遍历序列是:FDGBACHE,其后序遍历序列是:FGDBHECA 求其前序遍历序列。一棵二叉树的前序遍历序列为ABDGCFK,中序遍历序列为DGBAFCK,则结点的后序遍历序列是( )A、ACFKDBG B、GDBFKCA C、KCFAGDB D、ABCDFKG七、排序(Sort):v 所谓排序,就是指整理文件中的记录,使之按关键字递增(或递减)次序排列起来。v 冒泡排序(Bubble Sorting):通过对待排序序列从后向前或从前向后(从下标较大的元素开始),依次比较相邻元素的排序码,若发现逆序则交换,使排序码较大的元素逐渐从前部移向后部或较小的元素逐渐从后部移

12、向前部(从下标较大的单元移向下标较小的单元)。v 直接选择排序(Selection Sorting):扫描整个线性表,从中选出最小的元素,将它交换到表的最前面;然后对剩下的子表采用同样的方法,直到子表空为止。v 直接插入排序(Insertion Sorting):每次将一个待排序的记录,按其关键字大小插入到前面已经排好序的子文件中的适当位置,直到全部记录插入完成为止。v 快速排序(Quick Sorting):任取待排序序列中的某个元素作为基准(一般取第一个元素),通过一趟排序,将待排元素分为左右两个子序列,左子序列元素的排序码均小于或等于基准元素的排序码,右子序列的排序码则大于基准元素的排序

13、码,然后分别对两个子序列继续进行排序,直至整个序列有序。各种内部排序方法的比较排序方法时间复杂度空间复杂度最好时间平均时间最坏时间直接插入O(n)O(n2)O(1)直接选择冒 泡快 速O(nlgn)O(lgn)堆对一个具有n个元素的序列进行冒泡排序,在最坏情况下,要进行交换的次数是( )A、n(n+1)/2 B、n(n-1)/2 C、n*n/2 D、n(n+1)/2-1对n个元素进行冒泡排序过程中,最好情况下的时间复杂性为( )A、O(1) B、O(log2n) C、O(n2) D、O(n)对n个元素进行快速排序的过程中,平均情况下的时间复杂性为( )A、O(1) B、O(lgn) C、O(n

14、2) D、O(nlgn)八、查找(Searching):v 所谓查找是指给定一个值K,在含有n个结点的表中找出关键字等于给定值K的结点。若找到,则查找成功,返回该结点的信息或该结点在表中的位置;否则查找失败,返回相关的提示信息。v 顺序查找(Sequential Search)的基本思想是:从表的一端开始,顺序扫描线性表,依次将扫描到的结点关键字和给定值K相比较,若当前扫描到的结点关键字与K相等,则查找成功;若扫描结束后,仍未找到关键字等于K的结点,则查找失败。顺序查找即适用顺序存储结构,又适用链式存储结构。查找成功的平均查找长度为:(n为结点数目)(1+2+3+4+n) / n = (n+1

15、)/2v 二分查找(Binary Search)又称折半查找,它是一种效率较高的查找方法,二分查找要求线性表是有序表,即表中结点按关键字有序,并且要用向量作为表的存储结构。另外,二分查找只适用顺序存储结构,在链式存储结构上无法实现二分查找。查找成功时的平均查找长度:当n很大时,可用近似公式: lg(n+1)-1 表示二程序设计2.1 程序设计方法与风格程序设计是一门技术,需要相应理论、技术、方法和工具来支持。程序设计方法和技术的发展而言,主要经过了结构化程序设计和面向对象的程序设计阶段。养成良好的程序设计的设计风格,主要考虑下述的因素:1. 源程序文档化源程序文档化应考虑如下几点:(1)符号名

16、的命名:符号名的命名有一定含义,便于理解(2)程序注释:正确的注释帮助读者理解程序(3)视觉组织:程序层次清晰2. 数据说明的方法数据说明应考虑如下几点:(1)数据说明的次序规范化(2)说明语句中变量安排有序化。(3)使用注释来说明复杂数据结构3. 语句的结构程序应该简单易懂,语句构造应该简单直接。应该注意的是:(1)在一行内只写一条语句(2)程序编写应优选考虑清晰性(3)除非对效率有特殊要求,程序编写要清晰第一、效率第二(4)首先要保证程序正确,然后要求提高速度(5)避免使用临时变量而使程序可读性下降(6)避免不必要的转移(7)尽可能使用库函数(8)避免使用复杂的条件语句(9)尽量减少使用“

17、否定”条件的条件语句(10)数据结构要有利于程序的简化(11)要模块化,使模块功能尽可能单一化(12)利用信息隐藏,确保每一个模块的独立性(13)从数据出发去构造程序(14)不要修补不好的程序,要重新编写 4. 输入和输出 无论是批处理的输入和输出方式,还是交互式的输入和输出方式,在设计和编程时都应该考虑如下原则:(1)对所有的输入数据都要检验数据的合理性(2)检查输入项的各种重要组合的合理性(3)输入格式要简单。(4)输入数据时,应允许使用自由格式(5)应允许缺省值(6)输入一批数据时,最好使用输入结束标志(7)在交互式输入/输出方式进行输入时,要在屏幕上使用提示符明确提示输入要求,在数据输

18、入过程中和输入结束时应在屏幕给出状态信息(8)当程序设计语言对输入格式有严格要求时,应保持输入格式与输出语句的一致性。给所有输入加注释,并设计输出报表格式。2.2 结构化程序设计2.2.1 结构化程序设计的原则 结构化程序设计方法主要原则包括: 1. 自顶向下。设计程序时先考虑总体,后考虑细节 2. 逐步求精。对复杂问题,逐步细化。 3. 模块化。 4. 限制使用goto语句2.2.2 结构化程序的基本结构与特点 结构化程序设计方法是程序设计的先进方法和。和采用结构化程序设计方法编写程序,可使程序结构良好、易读、易理解、易维护。结构化程序设计方法基本可用三种基本结构就可实现。1. 顺序结构顺序

19、结构是顺序顺序执行结构,即是按照程序语句的自然顺序,一条一条语句地执行。2. 选择结构选择结构又称分支结构,它包括简单选择和多分支选择,这种结构可以根据给定条件,判断执行哪一个分支中的语句。3. 重复结构重复结构又称为循环结构。它根据给定的条件判断是否重复执行某一段相同的程序。2.2.3 结构化程序设计原则和方法的应用在结构化程序设计的具体实施中,要注意把握如下要素:(1)使用程序设计语言中的顺序、选择、循环等控制结构表示程序的控制逻辑(2)选用的控制结构只准许有一个入口和一个出口(3)程序语句组成容易识别的程序专项,每块只有一个入口和一个出口(4)复杂结构应该用嵌套的基本控制结构进行组合嵌套

20、来实现(5)语言中所没有的控制结构,应该采用前后一致的方法来模拟(6)严格控制GOTO语句使用。2.3 面向对象的程序设计2.3.1 关于面向对象方法面向对象(Object Oriented)方法已经发展成为主流的软件开发方法。面向对象方法的形成起源于实现语言,首先对设计语言的研究,随之形成面向对象分析和设计方法。面向对象方法的本质,就是主张从客观世界固有的事物出发来构造系统,提倡用人类在现实生活中常用的思维方法来认识、理解和描述客观事物,强调最终建立的系统能够映射问题域。也就是说,系统中的对象以及对象之间的关系能够如实反映问题域中固有事物及其关系。面向对象方法有如下优点: 1. 与人类习惯的

21、思维方法一致 面向对象和技术以对象为核心,对象是由数据和容许的操作组成的封装体,与客观实体有直接的对应关系。对象之间通过传递消息互相联系,以模拟现实世界中不同事物彼此之间的联系。如CD播放器、媒体播放器、软件窗口等等 2. 稳定性好 面向对象的软件系统的结构是根据问题领域的模型建立起来的,当对系统的功能需求变化时并不会引起软件结构的整体变化,往往仅需要作一些局部性的修改。 3. 可重用性好软件重用是指在不同的软件开发过程中重复使用相同或相似软件元素(一般称为类)的过程。重用是提高软件生产率的最主要的方法。利用可重用的软件成分构造新的软件系统,一个对象类可以重复使用,对象类可以创建,也以在已有的

22、类上修改,但不影响原有类。 4. 易于开发大型软件产品 可以把一个大型产品看作一系列互相独立的小产品来处理,这样不公降低了技术难度,而又使开发工作的管理变得容易。 5. 可维护性好 一般用传统的开发方法和面向过程的方法开发出来的软件很难维护,而面向对象的方法开发的软件可维护性好。 (1)稳定性较好 (2)易于修改 (3)易于理解 (4)易于测试和调试2.3.2 面向对象方法的基本概念 关于面向对象方法,对其概念有许多不同的看法,但都涵盖了对象及对象属性、方法、类、继承、多态性几个基本要素。 1. 对象(object)对象是面向对象方法中最基本的概念。对象用来表示客观世界中的任何实体。面向对象的

23、程序设计方法中涉及的对象是系统中用来描述客观事物的一个实体,是构成系统的一个基本单位,它由一组表示其静态特征的属性和它可执行的一组操作组成。对象有如下特点:(1)标识惟一性(2)分类性(3)多态性(4)封装性(5)模块独立性好2. 类(Class)和实例(Instance)将属性、操作相似的对象归为类,类具有共同属性、共同方法的对象的集合。如中图中命令按钮就是同类对象。3. 消息(Message)面向对象的世界是通过对象与对象彼此的相互合作来推动的,对象间的这种相互合作需要一个机制协助进行,这的机制称为“消息”。消息是一个实例与另一个实例之间传递的信息,它请求对象执行某一处理或回答某一要求的信

24、息,它统一了数据流和控制流。一个消息由三部分组成:(1)接收消息的对象的名称(2)消息标识符(也称消息名)(3)零个或多个参数比如在窗体上画一个圆,对象名MyForm,消息名Circle,参数(50,50)为圆心,25为半径MyForm.Circle (50,50),254. 继承(Inheritance)继承是面向对象的方法的一个主要特征。继承是使用已有的类定义作为基础(直接获得已有的性质和特征)建立新类的定义技术。已有的类可以当做基类引用,则新类可当做派生类引用。如右图就是VB中的基类:5. 多态性(Polymorphism) 对象根据所接受的消息而做出动作,同样的消息被不同的对象接受时可

25、导致完全不同的行动,该现象称为多态性三软件工程基础v 软件(Software):软件是一种产品(逻辑产品),指的是计算机中程序及其说明程序的各种文档。“程序”是计算任务的处理对象和处理规则的描述;“文档”是有关计算机程序功能、设计、编制、使用的文字或图形资料。v 软件危机的表现:1、软件需求的增长得不到满足2、软件开发成本和进度无法控制3、软件质量难以保证4、软件不可维护或维护程度非常低5、软件成本不断提高6、软件开发生产效率的提高赶不上硬件的发展和应用需求的增长v 软件工程(Software Engineering):用工程化的方法、科学知识和技术原理来定义、开发、维护软件的一门学科。v 软

26、件工程的目标:付出较低的开发成本;达到要求的软件功能;取得较好的软件性能;开发的软件易于移植;需要较低的维护费用;能按时完成开发任务,及时交付使用;开发的软件可靠性高。v 软件工程研究的主要内容是软件开发技术和软件开发管理两个方面。v 软件生存周期:是指一个软件从提出开发要求开始直到该软件报废(停止运行)为止的整个时期。v 软件生存周期模型:是描述软件开发过程中各种活动如何执行的模型。v 常用的模型有:瀑布模型、增量模型、螺旋模型、喷泉模型、变换模型和基于知识的模型瀑布模型是将软件生存周期各个活动规定为依线性顺序连接的若干阶段的模型。主要包括问题定义及可行性分析、项目开发计划、需求分析、概要设

27、计、详细设计、编码、测试和维护几个阶段。下列描述中正确的是( ) A、程序就是软件 B、软件开发不受计算机系统的限制 C、软件既是逻辑实体,又是物理实体 D、软件是程序、数据与相关文档的集合二、软件可行性研究与项目开发计划:v 软件可行性研究的目的是用最小的代价在尽可能短的时间内确定该软件项目是否能够开发,是否值得去开发。v 可行性研究的任务:A、技术可行性B、经济可行性C、社会可行性(法律可行性)v 可行性研究的具体步骤:1、确定项目规模和目标2、研究正在运行的系统3、建立新系统的高层逻辑模型4、导出和评价各种方案5、推荐可行的方案6、编写可行性研究报告三、软件需求分析:v 需求分析是指开发人员要准确理解用户的要求,进行细致的调查分析,将用户非形式的需求陈述转化为完整的需求定义,再由需求定义转换到相应的形式功能规约(需求规格说明)的过程。v 需求分析的基本任务:1、问题识别A、功能需求B、性能需求C、环境需求D、用户界面需求2、分析与综合,导出软件的逻辑模型3、编写文档(需求规格说明书)v 需求分析的方法:1、结构化分析(Structured Anal

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1